史萊姆論壇

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

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

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

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

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2005-08-30, 06:45 PM   #1
kcfs983
註冊會員
榮譽勳章

勳章總數
UID - 12955
在線等級: 級別:0 | 在線時長:0小時 | 升級還需:5小時
註冊日期: 2002-12-16
VIP期限: 2006-02
文章: 72
精華: 0
預設 擲骰子的問題

請問各位大大幾個程式的問題

使用亂數產生一長度為n,範圍介於1~6的亂數陣列,並將該陣列以函數参數的方式回傳,來模擬擲了n次骰子的結果。

#include "stdio.h"
#include "stdlib.h"

// dist[6] : given distribution of each number's appearances
// result[n] : simulation result
// n : rolling a dice n times
//
void rolling(int dist[6], int result[][2], int n) {

//在這加入程式碼 }

void print(int vals[][2], int len) {
int i;
int cnt[6];
for(i=0; i<6; i++)
cnt[i]=0;
printf("Rolling result : ");
for(i=0; i<len; i++) {
printf("(%d,%d) ",vals[i][0],vals[i][1]);
int index=vals[i][0]-1;
cnt[index]++;
index=vals[i][1]-1;
cnt[index]++;
}
printf("\n");
for(i=0; i<6; i++) {
printf("\tdice(%d) = %4.1f \n",i+1,(double)cnt[i]/len*100);
}
printf("\n");
}

int main(){

const int n=100;
int dices[n][2];
int dist1[] = {3,3,3,6,6,12};
int dist2[] = {6,3,6,1,1,12};
int dist3[] = {1,1,2,1,1,4};

srand(time(NULL));
rolling(dist1,dices,n);
print(dices,n);
rolling(dist2,dices,n);
print(dices,n);
rolling(dist3,dices,n);
print(dices,n);

return 0;
}
kcfs983 目前離線  
送花文章: 0, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
舊 2005-08-31, 03:58 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 金幣
預設

#include <stdio.h>
#define random(num) (rand() % (num)) /* random 取亂數 */
#define randomize() srand((unsigned)time(NULL)) /* randomize 清除取亂數種子表 */
#define clrscr() system("CLS") /* 畫面清除 */
#define pause() system("PAUSE") /* 暫停畫面 */
#define S 100 /* 設定巨集數值 S 為 100,擲骰子次數 */
#define U 6 /* 設定巨集數值 U 為 6,當骰子的數字 */
int pr_s(int au[]); /* 顯示擲骰子結果 */
int run_c(int au[]);/* 執行擲骰子+統計 */

main()
{
int au[u]={0};

run_c(au);

pr_s(au);


pause();
}

run_c(int au[])
{
int i,c;
randomize();

for(i=0;i<S;i++)
{
c=random(U);
au[c]++;
}
}

pr_s(int au[]) /* 顯示擲骰子結果 */
{
int i;
clrscr();
printf("擲骰子 %d 次:\n",S);
for(i=0;i<U;i++)
{
printf("\n%d 出現 %5d 次,機率為 % 3.1f %%",i+1,au[i],(float)au[i]/S*100);
}
printf("\n\n");
}
__________________
在「專業主討論區」中的問題解決後,要記得按一下 http://forum.slime.com.tw/images/stamps/is_solved.gif 按鈕喔,
這是一種禮貌動作。

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

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

迪西:「再見~ 再見~」

Otaku Culture Party 關心您 ...
getter 目前離線  
送花文章: 37855, 收花文章: 6441 篇, 收花: 26052 次
回覆時引用此帖
舊 2005-08-31, 04:32 AM   #3 (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 金幣
預設

#include "stdio.h"
#include "stdlib.h"
#define random(num) (rand() % (num)) /* random 取亂數 */
#define randomize() srand((unsigned)time(NULL)) /* randomize 清除取亂數種子表 */
#define clrscr() system("CLS") /* 畫面清除 */
#define pause() system("PAUSE") /* 暫停畫面 */

/*
dist[6] : given distribution of each number's appearances
result[n] : simulation result
n : rolling a dice n times
*/
void rolling(int dist[6], int result[][2], int n) {
int i,c;

randomize();

for(i=0;i<n;i++)
{
c=random(6);
result[i][0]=i+1;
result[i][1]=dist[c];
}
}

void print(int dist[6],int vals[][2], int len) {
int i;
int cnt[6]={0};
int index;

/* for(i=0; i<6; i++) */
/* cnt[i]=0; */

clrscr();
printf("Rolling result : ");

for(i=0;i<6;i++)
printf("(%d) ",dist[i]);

printf("\n");

for(i=0; i<len; i++) {
printf("(%3d,%2d) ",vals[i][0],vals[i][1]);

/* int index=vals[i][0]-1; */

index=vals[i][1]-1;
cnt[index]++;
}
printf("\n");

for(i=0; i<6; i++) {
printf("\tdice(%d) = %4.1f \n",i+1,(double)cnt[i]/len*100);
}

printf("\n");
pause();
}

int main(){

const int n=100;
int dices[n][2];
int dist1[] = {3,3,3,6,6,12};
int dist2[] = {6,3,6,1,1,12};
int dist3[] = {1,1,2,1,1,4};


srand(time(NULL));
rolling(dist1,dices,n);
print(dist1,dices,n);
rolling(dist2,dices,n);
print(dist2,dices,n);
rolling(dist3,dices,n);
print(dist3,dices,n);
}
getter 目前離線  
送花文章: 37855, 收花文章: 6441 篇, 收花: 26052 次
回覆時引用此帖
舊 2005-08-31, 04:48 AM   #4 (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 金幣
預設

#include "stdio.h"
#include "stdlib.h"
#define random(num) (rand() % (num)) /* random 取亂數 */
#define randomize() srand((unsigned)time(NULL)) /* randomize 清除取亂數種子表 */
#define clrscr() system("CLS") /* 畫面清除 */
#define pause() system("PAUSE") /* 暫停畫面 */

/*
dist[6] : given distribution of each number's appearances
result[n] : simulation result
n : rolling a dice n times
*/
void rolling(int result[][2], int n) {
int i,c;

randomize();

for(i=0;i<n;i++)
{
result[i][0]=i+1;
result[i][1]=random(6)+1;
}
}

void print(int vals[][2], int len) {
int i;
int cnt[6]={0};
int index;

/* for(i=0; i<6; i++) */
/* cnt[i]=0; */

clrscr();
printf("Rolling result : \n");

for(i=0; i<len; i++) {
printf("(%3d,%2d) ",vals[i][0],vals[i][1]);

/* int index=vals[i][0]-1; */

index=vals[i][1]-1;
cnt[index]++;
}
printf("\n");

for(i=0; i<6; i++) {
printf("\tdice(%d) = %4.1f %%\n",i+1,(double)cnt[i]/len*100);
}

printf("\n");
pause();
}

int main(){

const int n=100;
int dices[n][2];

rolling(dices,n);
print(dices,n);
}
getter 目前離線  
送花文章: 37855, 收花文章: 6441 篇, 收花: 26052 次
回覆時引用此帖
發文 回覆



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

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


所有時間均為台北時間。現在的時間是 08:57 PM


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


SEO by vBSEO 3.6.1