HDOJ 2098 分拆素数和
来源:互联网 发布:淘宝联盟规则 编辑:程序博客网 时间:2024/05/20 07:38
分拆素数和
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 29627 Accepted Submission(s): 12821
Problem Description
把一个偶数拆成两个不同素数的和,有几种拆法呢?
Input
输入包含一些正的偶数,其值不会超过10000,个数不会超过500,若遇0,则结束。
Output
对应每个偶数,输出其拆成不同素数的个数,每个结果占一行。
Sample Input
30260
Sample Output
32
本题目的要求是把一个偶数n拆成两个不同素数的和,如果单纯考虑只拆为两个数字的和,那么就是从1 + n-1,2 + n-2,3 + n-3.....
那么只需将i从n=2开始判断(1不是素数)i和n-i是否为素数,前提是i<n/2,因为n是偶数。
判断是否为素数,判断到sqrt(n);
代码如下:
#include<stdio.h>
#include<math.h>
int is_prime(int n)
{
for(int i=2;i<=sqrt(n);i++)
{
if(n%i==0)
return 0;
}
return 1;
}
int main()
{
int n,sum;
while(~scanf("%d",&n)&&n)
{
sum=0;
for(int i=2;i<n/2;i++)
{
if(is_prime(i)&&is_prime(n-i))
sum++;
}
printf("%d\n",sum);
}
return 0;
}
0 0
- hdoj 2098 分拆素数和
- hdoj 2098 分拆素数和
- hdoj 2098 分拆素数和
- hdoj.2098 分拆素数和 20140723
- hdoj 2098 分拆素数和
- HDOJ 2098 分拆素数和
- HDOJ 2098 分拆素数和
- hdoj--2098--分拆素数和(水题)
- HDOJ 2098 分拆素数和
- HDOJ 2098 分拆素数和
- hdoj-2098-分拆素数和
- hdoj-2098-分拆素数和
- HDOJ--2098分拆素数和
- hdoj 2098 分拆素数和
- HDOJ 2098 分拆素数和
- HDOJ 2098 分拆素数和
- HDOJ 分拆素数和 2098(素数打表)
- hdoj 2098 分拆素数和 【素数打表】
- iOS 自定义库文件
- 斯坦福大学机器学习——EM算法求解高斯混合模型
- PopupWindow的动画效果
- C#使用ODBCl连接MySql详细教程
- hibernate jpa manyToOne级联操作时,update时报出identifier of an instance of 问题的解决方案及update问题
- HDOJ 2098 分拆素数和
- WebAPI GET和POST请求的几种方式
- Snapdragon Flight
- 经济基础知识三
- 【集群】redis 3.0的集群部署
- Windows驱动的彻底删除
- Linux Shell中的特殊符号和含义简明总结(包含了绝大部份)
- DarunGrim3安装使用说明
- Java异常处理和设计