在一行中按照格式“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;
}