code.club

 找回密碼
 立即註冊
搜索
查看: 10666|回復: 2
打印 上一主題 下一主題

求2到1000中的所有質數

[複製鏈接]
跳轉到指定樓層
樓主
發表於 2015-3-3 23:28:10 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
#include <stdio.h>

int isprime(int i);//這裡變數i不影響其它函數內的變數也叫i

int main(void)
{
int i;
  for(i=2;i<=1000;i++)
  if(isprime(i)) printf("%d ",i);
    return 0;
  }
  
  int isprime(int i)
  {
  int j;
  for(j=2;j<=i/2;j++)
      if(i%j==0) return 0;//這個程式區塊是說,一旦i%j==0就立即return 0了。如果整個for()都沒有return 0,則本函數就return 1
    return 1;
        }
   
回復

使用道具 舉報

沙發
 樓主| 發表於 2015-3-4 00:30:23 | 只看該作者
我自己的寫法:

#include <stdio.h>

int main(void)
{
int i,j,prime;

for(i=2;i<=1000;i++){
  prime=1; //讓prime在 j 迴圈完之後又回到1
  for(j=2;j<=(i/2);j++)
  {
   if(i%j==0) prime=0;
   }
   if(prime==1) printf("%d ",i);
   }
   return 0;
   }
回復 支持 反對

使用道具 舉報

板凳
 樓主| 發表於 2015-6-15 22:34:17 | 只看該作者
輸入一正數求它包含的最大質數


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

int main(void) {
       
        int x,i,j,prime,biggest;
        do{
        printf("Please enter a positive number:\n");
        scanf("%d",&x);
}while(x<=0);

for(i=2;i<=x;i++) {
        prime = 1;
        for(j=2;j<=i/2;j++) {
                if(i%j==0) {
                        prime=0;
                break;}
        }
        if(prime==1) biggest=i;
}

printf("The biggest prime for %d is %d.\n",x,biggest);

return 0;
}
回復 支持 反對

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即註冊

本版積分規則

小黑屋|手機版|Archiver|code.club  

GMT+8, 2024-12-4 01:11 , Processed in 0.081222 second(s), 17 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表