#include <stdio.h>
#include <stdlib.h>

int* sushu(int n)	//找出n以内的所有质数
{
	int i,j,flage = 0,t = 0,s[32767];
	for(i=2;i<n;i++)
	{
		for(j=2;j<i;j++)
		{
			if(0 == i%j)	//说明i是非质数
				break;
		}
		if(i == j)	
			s[t++] = i;	
	}	
	return s;
}

int judge(int tmp,int s[],int sum)
{
	int i;
	for(i=0;s[i]!=0;i++)
	{
		if(sum == tmp + s[i])
		{
			if(tmp != s[i])
				return 1;
		}		
	}	
}

int main(void)
{
	int i,n,a,b,count = 0,flage = 0;
	int *ptr;
	scanf("%d",&n);
	
	ptr = sushu(n);
	for(i=0;*(ptr+i)!=0;i++)
	{
		if(n/2 == *(ptr+i)) //判断是否是两个相同的质数相加
		{
			flage = 1;
		}	
	}	
	for(i=0;i<n/2;i++)
	{
		if(1 == judge(*(ptr+i),ptr,n))
		{
			count++;
		}		
	}
	if(1 == flage)
	{
		printf("%d",count/2+1);
	}
	else
		printf("%d",count/2);
    return 0;
 
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论