史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2007-11-05, 08:23 AM   #1 (permalink)
管理員
 
getter 的頭像
榮譽勳章
UID - 6433
在線等級: 級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時
註冊日期: 2002-12-08
住址: 天線星球
文章: 8157
精華: 0
現金: 19955 金幣
資產: 765391 金幣
預設 運用 scanf 輸入範圍

還可以用 scanf 做外部輸入範圍

以 2 的指數作範圍
語法:
//質數計算 

#include <stdio.h>  //載入函式庫 stdio 
#include <stdlib.h> //載入函式庫 stdlib
#include <math.h>   //載入函式庫 math
#define clrscr() system("CLS") //畫面清除巨集 
#define pause() puts("\n") & system("PAUSE") //畫面暫停巨集 


main()
{
 unsigned long int i,j,mod_counter; //for_loop 變數 i,j;整除統計  mod_counter
 unsigned long int min=0,max=0,counter = 0;
 int inupt_exp;
  
 clrscr(); //畫面清除
    
 printf ("\n請輸入欲求取質數的位元數:"); 
 scanf("%d",&inupt_exp);
 
 clrscr(); //畫面清除
 printf ("\n %d 位元質數:\n",inupt_exp); 
 printf ("\n最小質數"); 
 
 for ( i=1; i<=pow(2,inupt_exp)-1; i++ ) { //取餘數除法的Loop1,i 為被除數   3
     mod_counter = 0; //整除統計歸零 
     for ( j=2; j<=i; j++ )  //取餘數除法的Loop2,j 為除數 
          if ( i%j == 0  ) mod_counter ++ ; //當被整除時,整除計數 +1 
 
     if ( mod_counter == 1 ) {  //當被整除次數只有 1 次,並輸出最大質數 
          counter ++; //統計質數的個數 
         min = i; //紀錄最小的質數
          printf ("為 %d\n",i); 
        } 
    }

 if ( min == 0) printf (" 沒有\n");
 printf ("\n最大質數");  
 if ( max > 0) printf ("為 %d\n",max); else  printf (" 沒有\n");
 printf ("\n共有 %d 個值數\n",counter);
 
 pause(); //畫面暫停 
}

用開始與結束的值做範圍
語法:
//質數計算 

#include <stdio.h>  //載入函式庫 stdio 
#include <stdlib.h> //載入函式庫 stdlib
#include <math.h>   //載入函式庫 math
#define clrscr() system("CLS") //畫面清除巨集 
#define pause() puts("\n") & system("PAUSE") //畫面暫停巨集 
#define swap(x,y) (x^=y^=x^=y) //數值交換巨集 

main()
{
 unsigned long int i,j,mod_counter; //for_loop 變數 i,j;整除統計  mod_counter
 unsigned long int min=0,max=0,counter=0;
 unsigned long int inupt_A,inupt_B;
 
 clrscr(); //畫面清除   
 
 printf ("\n請輸入欲求取質數的數值 A :"); 
 scanf("%d",&inupt_A);
 printf ("\n請輸入欲求取質數的數值 B :"); 
 scanf("%d",&inupt_B);
 
 clrscr(); //畫面清除               
 printf ("\n%d ~ %d 的質數:\n",inupt_A,inupt_B); 
 printf ("\n最小質數");
 
 if (inupt_A > inupt_B)  //A值 > B值,就互換數值 
     swap(inupt_A,inupt_B);

 for ( i=inupt_A; i<=inupt_B; i++ ) { //座取餘數除法的Loop1,i 為被除數    
     mod_counter = 0; //整除統計歸零 
     for ( j=2; j<=i; j++ ) //座取餘數除法的Loop2,j 為除數 
          if ( i%j == 0  ) mod_counter ++ ; //當被整除時,整除計數 +1 

     if ( mod_counter == 1 ) {  //當被整除次數只有 1 次,並輸出最大質數 
          counter ++; //統計質數的個數 
          if ( counter == 1 ) {
              min = i; //紀錄最小的質數
              printf ("為 %d\n",i);              
             }
          max = i; //紀錄最大的質數  
        } 
    }
    
 if ( min == 0) printf (" 沒有\n");
 printf ("\n最大質數");
 if ( min > 0) printf ("為 %d\n",max); else  printf (" 沒有\n");
 printf ("\n\n共有 %d 個值數\n",counter);

 pause(); //畫面暫停 
}

此帖於 2007-11-05 11:18 AM 被 getter 編輯.
__________________
在「專業主討論區」中的問題解決後,要記得按一下 http://forum.slime.com.tw/images/stamps/is_solved.gif 按鈕喔,
這是一種禮貌動作。

一樣是在「專業主討論區」中發問,不管問題解決與否,都要回應別人的回答文喔。
不然搞 [斷頭文],只看不回應,下次被別人列入黑名單就不要怪人喔。

天線寶寶說再見啦~ ... 天線寶寶說再見啦~

迪西:「再見~ 再見~」

Otaku Culture Party 關心您 ...
getter 目前離線  
送花文章: 37855, 收花文章: 6441 篇, 收花: 26052 次
回覆時引用此帖
舊 2007-11-05, 09:11 AM   #2 (permalink)
管理員
 
getter 的頭像
榮譽勳章
UID - 6433
在線等級: 級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時
註冊日期: 2002-12-08
住址: 天線星球
文章: 8157
精華: 0
現金: 19955 金幣
資產: 765391 金幣
預設 運算加速

如過運算上要更快的話...
1.除了原來的只有自己能整除自己外。
2.將偶數過濾掉,只保留公因數 2(偶數部分只有 2 是質數)。
3.整除時,把除數的偶數過濾掉。

最簡單的的改良
語法:
//質數計算 

#include <stdio.h>  //載入函式庫 stdio 
#include <stdlib.h> //載入函式庫 stdlib
#define clrscr() system("CLS") //畫面清除巨集 
#define pause() puts("\n") & system("PAUSE") //畫面暫停巨集 
#define Max 60 //定義最大值常數 = 60 

int main()
{
 int i,j,mod_counter; //for_loop 變數 i,j;整除統計  mod_counter
 
 clrscr(); //畫面清除 

 for ( i=2; i<=Max; i++ ) { //取餘數除法的Loop1,i 為被除數
 
     if ( i%2==0 ) { //過濾偶數 
         if ( i == 2 ) //將公因數 2 保留 
             printf ("%3d,\t",i); 
         continue; //略過此次回圈運算 
        }
        
     mod_counter = 0; //整除統計歸零  
     for ( j=3; j<=i; j+=2 ) { //取餘數除法的Loop2,j 為除數(奇數運算) 
           if ( i%j == 0  ) mod_counter ++ ; //當被整除時,整除計數 +1 
         }           
     if ( mod_counter == 1 ) printf ("%3d,\t",i); 
     //當被整除次數只有 1 次,為質數並顯示 
    }
    
 pause(); //畫面暫停 
}


位元輸入改
語法:
//質數計算 

#include <stdio.h>  //載入函式庫 stdio 
#include <stdlib.h> //載入函式庫 stdlib
#include <math.h>   //載入函式庫 math
#define clrscr() system("CLS") //畫面清除巨集 
#define pause() puts("\n") & system("PAUSE") //畫面暫停巨集 


main()
{
 unsigned long int i,j,mod_counter; //for_loop 變數 i,j;整除統計  mod_counter
 unsigned long int min=0,max=0,counter = 0;
 int inupt_exp;
 
 clrscr(); //畫面清除
    
 printf ("\n請輸入欲求取質數的位元數:"); 
 scanf("%d",&inupt_exp);
 
 clrscr(); //畫面清除
 printf ("\n %d 位元質數:\n",inupt_exp); 
 printf ("\n最小質數");
 
 for ( i=1; i<=pow(2,inupt_exp)-1; i++ ) { //取餘數除法的Loop1,i 為被除數 
 
     if ( i%2==0 ) { //過濾偶數 
         if ( i == 2 ) { //將公因數 2 保留 
             counter ++; //統計質數的個數 
             min = i; //紀錄最小的質數 
             printf ("為 %d\n",i);              
            }
         continue; //略過此次回圈運算  
        }        
  
     mod_counter = 0; //整除統計歸零 
     for ( j=3; j<=i; j+=2 )  //取餘數除法的Loop2,j 為除數(奇數運算) 
          if ( i%j == 0  ) mod_counter ++ ; //當被整除時,整除計數 +1 

     if ( mod_counter == 1 ) {  //當被整除次數只有 1 次,並輸出最大質數 
          counter ++; //統計質數的個數 
          max = i; //紀錄最大的質數 
        } 
    }
    
 if ( min == 0) printf (" 沒有\n");
 printf ("\n最大質數");  
 if ( max > 0) printf ("為 %d\n",max); else  printf (" 沒有\n");
 printf ("\n共有 %d 個值數\n",counter);
 
 pause(); //畫面暫停 
}

範圍輸入改
語法:
//質數計算 

#include <stdio.h>  //載入函式庫 stdio 
#include <stdlib.h> //載入函式庫 stdlib
#include <math.h>   //載入函式庫 math
#define clrscr() system("CLS") //畫面清除巨集 
#define pause() puts("\n") & system("PAUSE") //畫面暫停巨集 
#define swap(x,y) (x^=y^=x^=y) //數值交換巨集 

main()
{
 unsigned long int i,j,mod_counter; //for_loop 變數 i,j;整除統計  mod_counter
 unsigned long int min=0,max=0,counter=0;
 unsigned long int inupt_A,inupt_B;
 
 clrscr(); //畫面清除   
 
 printf ("\n請輸入欲求取質數的數值 A :"); 
 scanf("%d",&inupt_A);
 printf ("\n請輸入欲求取質數的數值 B :"); 
 scanf("%d",&inupt_B);
 
 clrscr(); //畫面清除               
 printf ("\n%d ~ %d 的質數:\n",inupt_A,inupt_B); 
 printf ("\n最小質數");
 
 if (inupt_A > inupt_B)  //A值 > B值,就互換數值 
     swap(inupt_A,inupt_B);

 for ( i=inupt_A; i<=inupt_B; i++ ) { //取餘數除法的Loop1,i 為被除數  
 
      if ( i%2==0 ) { //過濾偶數 
         if ( i == 2 ) { //將公因數 2 保留 
             counter ++; //統計質數的個數 
             min = i; //紀錄最小的質數 
             max = i; //紀錄最大的質數 
             printf ("為 %d\n",i);   
            }
         continue; //略過此次回圈運算 
        }   
   
     mod_counter = 0; //整除統計歸零 
     for ( j=3; j<=i; j+=2 )  //取餘數除法的Loop2,j 為除數(奇數運算) 
          if ( i%j == 0  ) mod_counter ++ ; //當被整除時,整除計數 +1  

     if ( mod_counter == 1 ) {  //當被整除次數只有 1 次,並輸出最大質數 
          counter ++; //統計質數的個數 
          if ( counter == 1 ) {
              min = i; //紀錄最小的質數 
              printf ("為 %d\n",i);              
             }
          max = i; //紀錄最大的質數  
        } 
    }
    
 if ( min == 0) printf (" 沒有\n");
 printf ("\n最大質數");
 if ( min > 0) printf ("為 %d\n",max); else  printf (" 沒有\n");
 printf ("\n\n共有 %d 個值數\n",counter);

 pause(); //畫面暫停 
}

此帖於 2007-11-05 11:47 AM 被 getter 編輯.
getter 目前離線  
送花文章: 37855, 收花文章: 6441 篇, 收花: 26052 次
回覆時引用此帖
向 getter 送花的會員:
clout (2007-11-09)
感謝您發表一篇好文章
發文 回覆



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用


所有時間均為台北時間。現在的時間是 06:26 PM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2025, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1