使用 rand() 函數,必須 include 它的標頭檔 stdlib.h (stdlib 為 Standard Library, 標準函式庫)

rand() 將會傳回一個介於 0 到 RAND_MAX 之間的一個整數值,RAND_MAX 是 stdlib.h 定義的一個常數,其值在不同的系統有不同的大小

通常我們會搭配使用取餘數符號 % 來做運算,例如我們要取 0-9 的變數,可以寫成 a=rand() % 10


例如:
取 1-10 的亂數 a=(rand() % 10) +1

取 1-100 的亂數 a=(rand() % 100) +1

取 100-1000 的亂數 a=(rand() % 901) +10


我們可以規納出以下的規則: ( rand() % (最大值-最小值+1) ) + 最小值


當程式重複執行數次之後,會發現所得到的亂數是一樣的

這是因為它由上一個數值產生出下一個亂數,而一開始系統都是 0,所以每次產生出來的亂數才會一樣。

因此我們可以用 srand() 函數改變一開始的亂數值( srand() 函數也是定義在 stdlib.h), srand() 需要一個參數做為種子,

以產生一個新的亂數數列,而這個參數我們通常以目前的時間傳入,也就是使用 time() 函數,而 time() 是定義在 time.h 中

最至於是不是每次呼叫 rand() 前就必須使用 srand() 一次,答案是否定的,各位只要在程式的一開頭執行一次 srand() 即可,

之後出來的亂數就會和上次執行的不一樣。

 

2  

#include 
#include 
void sortF(int*);
int main(int argc, char *argv[])
{
  int n =0,i=0,j=0,array[5][10]={0};
  scanf("%d",&n);
  srand(time(NULL));
  
  for(i=0;i<n;i++){
      for(j=0;j<10;j++){  
          array[i][j] = (rand()%(198+1)+(-99));
      }
      for(j=0;j<10;j++){  
          printf("%3d ",array[i][j]);
      }
      printf("\n");
      sortF(array[i]);
      printf("\n\n");
  }
  
  system("PAUSE");	 
  return 0;
}
//排序(從小排到大) 
void sortF(int* iarray){
     int i,j,tmp;
     
     for(i=0;i<10;i++){
         for(j=0;j<9;j++){
             if(iarray[j] > iarray[j+1]){
                 tmp = iarray[j];
                 iarray[j] = iarray[j+1];
                 iarray[j+1] = tmp;
             }
         }                  
     }
     for(i=0;i<10;i++){
         printf("%3d ",iarray[i]);                
     }
}

 

 2  

#include 
#include 
#include 
int main(int argc, char *argv[])
{
  int n =0,i=0,j=0,c=0;
  scanf("%d",&n);
  srand(time(NULL));
  
  //A~Z的ASCII對應到的十進位為65~90
  //a~z的ASCII對應到的十進位為97~122 
  for(i=0;i<n;i++){ 
      do{
      	          //產生65~122的亂數
		  // 公式:( rand() % (最大值-最小值+1) ) + 最小值 
		  //所以rand()%(122-65+1)+(65) 
          c = (rand()%(57+1)+(65));
      }while(c >90 && c < 97);
          //91~96並不是英文字 
	  //所以當產生出來的亂數是大於90且小於97
	  //也就是91~96,那就得重新產生一個亂數 
      printf("%c ",c);
  }
  
  system("PAUSE");	 
  return 0;
}

 

 

題目:

要求使用者輸入數值n,其中1<=n<=5 ,電腦會隨機輸出n個質數,

其中質數的範圍為300~1000並依照小至大排列

測試範例:

3

631 839 911

#include 
#include 
int is_prime(int);
int main(int argc, char *argv[])
{
  int n=0,i=0,array[6],radom,j,tmp=0;
  scanf("%d",&n);
  srand(time(NULL));
  for(i=0;i<n;i++){
  	while(1){
  		radom=(rand() %(1000-300+1) )+300;
  		if(is_prime(radom)){
  			array[i]=radom;
  			break;
  		}
  	}
  }
  for(i=0;i<n;i++){
  	for(j=0;j<n;j++){
  		if(array[i]<array[j]){
  			tmp=array[i];
  			array[i]=array[j];
  			array[j]=tmp;
  		}
  	}
  }
  for(i=0;i<n;i++){
    printf("%d ",array[i]);
  }
  system("PAUSE");	 
  return 0;
}
int is_prime(int num){
	int i;
	for(i=2;i<num;i++){
		if(num%i==0){
			return 0;
		}
	}
	return 1;
}

 

 

arrow
arrow

    Mark Zhang 發表在 痞客邦 留言(1) 人氣()