一道C语言的基本题(求100之内的素数)

慕容嫣儿 2012-07-18 08:48:15
【基本题】求100之内的素数
#include <stdio.h>
#include "math.h"
#define N 101
main()
{
int i,j,line,a[N];
for(i=2;i<N;i++) a[i]=i;
for(i=2;i<sqrt(N);i++) //这一句i<sqrt(N);什么意思,为什么这样可以改为N也可以运行正确
for(j=i+1;j<N;j++) //这一句改为j<sqrt(N);为何又不能运行正确.
{
if(a[i]!=0&&a[j]!=0)
if(a[j]%a[i]==0)
a[j]=0;}
printf("\n");
for(i=2,line=0;i<N;i++)0
{
if(a[i]!=0)
{printf("%5d",a[i]);
line++;}
if(line==10)
{printf("\n");
line=0;}
}
}

判断 81是否素数,只需判断81除2,3,,4,。。。9 只要没除尽的数就是素数
9就是81的开方了

如上两个注释的地方,搞不懂。求大家帮忙解答!!
...全文
2123 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
再睡一小会儿 2012-07-19
  • 打赏
  • 举报
回复
首先是素数的算法,根据素数的定义我们可以知道,一个数如果能被出了1或者它本身以外的其他数整除的话,这个数就不是素数。所以判断一个数是不是素数的方法是看这个数被任意一个比1大且不小于它的算术平方根(sqrt(x))的数整除。
这是Lz的代码:
// 循环的第一层是确定每次判断素数是,除数的可能取到的值的上限。由于被判断的数始终比除数大,所以只要
// 把sqrt(N)替换成任意比sqrt(N)大的值的话都没问题。
for(i=2;i<sqrt(N);i++) //这一句i<sqrt(N);什么意思,为什么这样可以改为N也可以运行正确
{
// 这里决定的是被判断的数可能取到的值,如果改成j<sqrt(N)的话,判断的就是1到sqrt(101)之间的素数
// 当然要出问题了
for(j=i+1;j<N;j++) //这一句改为j<sqrt(N);为何又不能运行正确.
{
if(a[i]!=0&&a[j]!=0)
if(a[j]%a[i]==0)
a[j]=0;
}
}
慕容嫣儿 2012-07-19
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 的回复:]
只解释第一个问题:
1.素数的原始概念(不说成定义),只能被1和N整除的整数叫素数,推出:不能被2至N-1整除

2.证实N为素数,只能用否定法,即寻找一个k,使N%k==0成立来否定“N是素数”

3.若N%k==0成立,则k称为N的因子,而N/k(商)也一定是N的因子(记为q)。即因子实际上是一对,找到k(已经证实了N不是素数)实际上就找到了q(不必证实。。)

4.k可能等于q……
[/Quote]
这就是我想知道的!!谢谢。。。马上给分!嘿嘿。。。
s_april_s 2012-07-19
  • 打赏
  • 举报
回复
判断N(N>2)是不是素数,则用2~sqrt(N)中的除,若能除尽则不是素数,

你这个算法就是1~100的数先把他们依次除以2~sqrt(N),若能除尽则标记为0,用if(a[i]!=0&&a[j]!=0)条件语句跳过这个数,
最大的数位N,则最多除的数为sqrt(N)

就算你把第一个标记的地方改为N只是增加了计算机的运行次数,所以能得出真确答案,

但下一句标记的地方是你要找出的1~N中的素数若你改成了sqrt(N),则这个算法求的就是1~sqrt(N)中的素数了;
AnYidan 2012-07-19
  • 打赏
  • 举报
回复
坛子里搜搜,
cao_julians 2012-07-19
  • 打赏
  • 举报
回复
只解释第一个问题:
1.素数的原始概念(不说成定义),只能被1和N整除的整数叫素数,推出:不能被2至N-1整除

2.证实N为素数,只能用否定法,即寻找一个k,使N%k==0成立来否定“N是素数”

3.若N%k==0成立,则k称为N的因子,而N/k(商)也一定是N的因子(记为q)。即因子实际上是一对,找到k(已经证实了N不是素数)实际上就找到了q(不必证实。。)

4.k可能等于q,即N==q*q,或q=sqrt(N);若k<sqrt(N),则一定有q>sqrt(N).这说明k和q是分布sqrt(N
)两边的-----若在2至sqrt(N)间不存在k是N的因子,则在sqrt(N)至N-1间不存在q----。

5.只在2至sqrt(N)间找k,若N%k==0,就能推出k是N的因子、N不是素数!

其实每一个知识点我们都知道,就是不会联系起来思考运用。
JXLFZ 2012-07-19
  • 打赏
  • 举报
回复
你的代码就没看了,至于这个i<sqrt(N)就是说能整除到i值,下一个可能不能整除或重复了。如:N = 9,那么N最大能整除的数就是3,至于4,5,6,7,8都不能整除;如 N = 16,那么N要整除的数是2或8其实是一样的,所以这个就存在一个重复。这个只是为了让算法更高效,你一直除到N也是行的,只是会做了很多没用的工
LanXLawlieT 2012-07-19
  • 打赏
  • 举报
回复
楼主,你的循环有点问题
首先外循环肯定是从2~N的,这是你要判断的数的范围
内循环中可以为j+1 ~ sqrt(N),也可以到N-1,这是内部循环判断是否是素数的关键,从2开始至sqrt(N)开始判断素数。
然后换行的话用line%10就好了,那样有点繁琐
ly1chee 2012-07-18
  • 打赏
  • 举报
回复
#include <stdio.h>
#include <math.h>

int IsPrime(int n)
{
int i, j = (int)sqrt(n);
if (n % 2 == 0)
return 0;
for (i = 2; i <= j; ++i)
if (n % i == 0)
return 0;
return 1;
}

int main(void)r
{
int i;
for (i = 1; i <= 100; ++i)
if (IsPrime(i))
printf("%d\n", i);
return 0;
}
W170532934 2012-07-18
  • 打赏
  • 举报
回复
这个是个算法的问题,证明我给忘记了,求素数的只要求到sqrt(n)就可以判断了。你的第一处换成n肯定是可以的啦。第二个就不行,原因很简单,你第二处是控制从1---100之间的数的,你还成这个了就只是求了1--10,里面有哪些个是素数的
W170532934 2012-07-18
  • 打赏
  • 举报
回复
楼主的程序写的有点怪异啊,为什么把sqrt放在上层循环咯,还不习惯呢。一般求素数会for(2 to sqrt(n))的
1.数字排列 2.奖金分配问 3.已知条件解整数 4.输入日期判断第几天 5.输入整数进行排序 6.用*号显示字母C的图案 7.显示特殊图案 8.打印九九口诀 9.输出国际象棋棋盘 10.打印楼梯并按条件打印笑脸 11.经典兔子问 12.判断素数 13.水仙花数问 14.正整数分解质因数 15.学习成绩划分 16.正整数其最大公约数和最小公倍数 17.统计英文字母/空格/数字个数 18.s=a+aa+aaa+aa...a的值 19.解"完数" 20.球体自由落下物理问 21.猴子吃桃问 22.乒乓球比赛抽签问 23.打印菱形图案 24.分数数列和 25.1+2!+3!+...+20!的和 26.利用递归方法5! 27.将输入字符以相反顺序打印 28.岁数问 29.解正整数位数 30.判断回文数 31.星期几猜测游戏 32.改变文本颜色 33.学习gotoxy()与clrscr()函数 34.练习函数调用 35.设置文本颜色 36.100之内素数 37.对10个数进行排序 38.3*3矩阵对角线元素之和 39.数字插入数组重新排序 40.将一个数组逆序输出 41.static定义静态变量用法 42.使用auto定义变量用法 43.使用static的另一用法 44.使用external的用法 45.使用register定义变量方法 46.宏#define命令练习(1) 47.宏#define命令练习(2) 48.宏#define命令练习(3) 49.#if #ifdef和#ifndef的综合应用 50.#include 的应用练习 51.学习使用按位与 & 52.学习使用按位或 | 53.学习使用按位异或 ^ 54.取一个整数从右端开始的4~7位。 55.学习使用按位取反~ 56.用circle画圆形 57.学用line画直线 58.用rectangle画方形 59.画图综合例子 60.画图综合例子2 61.打印杨辉三角形 62.学习putpixel画点 63.画椭圆ellipse 64.利用ellipse and rectangle画图 65.画个最优美的图案 66.输入3个数字按大小顺序输出 67.输入数组交换元素重新输出 68.多个整数后移位置问 69.圆圈报数问 70.计算一个字符串长度 71.编写输入/输出函数 72.创建链表 73.反向输出链表 74.连接两个链表 75.算一道简单目 76.调用函数1/2+1/4+...+1/n 77.填空练习(指向指针的指针) 78.找到年龄最大的人 79.字符串排序 80.海滩猴子分桃 81.已知公式条件数字 82.八进制转换为十进制 83.0-7所能组成的奇数个数 84.由两个素数之和表示的偶数 85.判断一个素数能被几个9整除 86.两个字符串连接程序 87.结构体变量传递 88.读取数字的整数值并打印出该值个数的* 89.数据加密 90.专升本一 91.时间函数举例1 92.时间函数举例2 93.时间函数举例3 94.一个猜数游戏 95.家庭财务管理小程序 96.计算字符串中子串出现的次数 97.输入字符并保存到磁盘 98.字符串转换成大写字母并输出保存 99.文件操作应用1 100.文件操作应用2

70,020

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧