如何加一个限定条件让他仅仅输出最小的N1,提供个思路或者代码,

在一行中按照格式“N = p + q”输出N的素数分解,其中p ≤ q均为素数。又因为这样的分解不唯一(例如24还可以分解为7+17),要求必须输出所有解中p最小的解。


#include<stdio.h>
int main()
{
    int n,n1,n2,j,k;
    scanf("%d",&n);
    for(n1=2;n1<n/2;n1++)
    {
        for(j=2;j<n1;j++)
        if(n1%j==0)
        break;
        if(j>=n1)
        n2=n-n1;
        else continue;
        for(k=2;k<n2;k++)
        if(n2%k==0)
        break;
        if(k>=n2)
        printf("%d = %d + %d",n,n1,n2); 
    }
    
    return 0;
}

供参考:

#include<stdio.h>
int  isPrime(int n)
{
    int i;
    if(n<=3) return n>1;
    for(i=2;i*i<=n;i++)
       if(n%i == 0) return 0;
    return 1;
}
int main()
{
    int i,n;
    scanf("%d",&n);
    for(i = 2; i <= n/2; i++){
        if(isPrime(i) && isPrime(n-i)){
           printf("%-d=%-d+%-d\n",n,i,n-i);//输出
           break;
        }
    }
    return 0;
}