<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
哈嘍各位友友們,我今天又學到了很多有趣的知識,現在迫不及待的想和大家分享一下!我僅已此文,手把手帶領大家探討利用試除法、篩選法求解素數的n層境界!都是精華內容,可不要錯過喲!!!
質數又稱素數。一個大於1的自然數,除了1和它自身外,不能被其他自然數整除的數叫做質數;否則稱為合數(規定1既不是質數也不是合數)。這裡以求解100~200之間的素數舉例講解
境界1實現思路分析:
看了文字的描述,大家可能理解的還是不夠深刻。這裡俺親自敲出程式碼輔助大家理解~
境界1原始碼:
#include<stdio.h> int main() { int count = 0;//記錄試除次數 int i = 0; int j = 0; for (i = 100; i <= 200; i++) { int flag = 1;//flag最終結果為1,表示i是素數,為0表示不是素數。 for (j = 2; j < i; j++) { count++; if (i % j == 0) { flag = 0; break; } } if(flag == 1) printf("%d ", i); } printf("n境界1試除總次數:%d", count); return 0; }
程式碼結果執行圖:
由境界1求解100~200之間的素數,需要試除3292次!!!可見其演演算法效率如何啦。
境界2實現思路分析:
境界2原始碼:
#include<stdio.h> int main() { int count = 0;//記錄試除次數 int i = 0; int j = 0; for (i = 101; i < 200; i+=2)//提前排除100到200之間的偶數,符合這個條件一定不是素數。 { int flag = 1;//flag最終結果為1,表示i是素數,為0表示不是素數。 for (j = 2; j < i; j++) { count++; if (i % j == 0) { flag = 0; break; } } if(flag == 1) printf("%d ", i); } printf("n境界2試除總次數:%d", count); return 0; }
程式碼結果執行圖:
由境界2求解100~200之間的素數,需要試除3241次,稍微比境界1好那麼一丟丟啦!但是其演演算法效率還是不盡人意。
境界3實現思路分析:
境界3原始碼:
#include<stdio.h> #include<math.h> int main() { int count = 0;//記錄試除次數 int i = 0; int j = 0; for (i = 100; i <= 200; i++) { int flag = 1;//flag最終結果為1,表示i是素數,為0表示不是素數。 for (j = 2; j <= sqrt(i); j++)//只需要試除2到sqrt(i)之間的整數即可 { count++; if (i % j == 0) { flag = 0; break; } } if (flag == 1) printf("%d ", i); } printf("n境界3試除總次數:%d", count); return 0; }
程式碼結果執行圖:
由境界4求解100~200之間的素數,只需要試除393次,相比於境界1和境界2的演演算法效率來說,已經有長足的改進啦!
境界4實現思路分析:
境界4原始碼:
#include<stdio.h> #include<math.h> int main() { int count = 0;//記錄試除次數 int i = 0; int j = 0; for (i = 101; i < 200; i += 2)//排除100到200之間的2的倍數,符合這個條件一定不是素數。 { int flag = 1;//flag最終結果為1,表示i是素數,為0表示不是素數。 for (j = 2; j <= sqrt(i); j++)//只需要試除2到sqrt(i)之間的整數即可 { count++; if (i % j == 0) { flag = 0; break; } } if (flag == 1) printf("%d ", i); } printf("n境界4試除總次數:%d", count); return 0; }
程式碼結果執行圖:
由境界4求解100~200之間的素數,試除總次數為342,是,綜合考慮了境界2和境界3的改良思想,已經達到了試除法的最高境界啦!
預備小知識
埃拉托色尼是一名古希臘的地理學家,他是世界上第一個計算出地球周長的人。埃拉托色尼素數篩選法可以很快速的計算出1到N之間的所有素數。埃拉托色尼素數篩選法大概的計算思路是:將n開根號,即N^0.5 ,去掉2到N^0.5中所有素數的倍數,剩下的數便都是素數了。例如求1到25中的素數有哪些,第一步是將25開根號,得到5;第二步將2到5的素數取出來,分別是2、3、5:再將2到25中且是2、3、5的倍數的數去掉,即去掉4、6、8、9、10、12、14、15、16、18、 20、21、22、24、25;剩下2、3、5、7、11、13、17、19便是1到25中的所有素數了。從上面我們可以看出篩選法和試除法其實有著本質上的區別,試除法是判斷每一個數是不是素數來達到目的;而篩選法不是如此,篩選法是將不是素數的數全部去除,然後得到餘下的數來達到目的~
境界5(基礎篩選法)實現思路分析:
境界5原始碼:
#include<stdio.h> int main() { int i = 0; int j = 0; int arr[100]; int count = 0; for (i = 0; i < 100; i++) { arr[i] = 100 + i;//將陣列先初始化儲存100到199。 //沒有儲存200也沒關係,200一定不是素數 } for (i = 0; i < 100; i++) { j = i + 1; while (j > 1) { count++; if (arr[i] % j == 0) arr[i] = 0; j = j - 1; } } for (j = 1; j < 100; j++) { if (arr[j] != 0) { printf("%d ", arr[j]); } } return 0; }
程式碼結果執行圖:
到此這篇關於C語言實現求解素數的N種方法總結的文章就介紹到這了,更多相關C語言求解素數內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45