查看單個文章
舊 2005-07-28, 01:33 PM   #4 (permalink)
mini
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:97 | 在線時長:9861小時 | 升級還需:135小時級別:97 | 在線時長:9861小時 | 升級還需:135小時級別:97 | 在線時長:9861小時 | 升級還需:135小時級別:97 | 在線時長:9861小時 | 升級還需:135小時級別:97 | 在線時長:9861小時 | 升級還需:135小時級別:97 | 在線時長:9861小時 | 升級還需:135小時級別:97 | 在線時長:9861小時 | 升級還需:135小時
註冊日期: 2002-12-07
文章: 13343
精華: 0
現金: 26452 金幣
資產: 3024312 金幣
預設

第二題就是迴圈內再加迴圈

for(i=1;i<=6;i++) {
for(j=1;j<=6;j++) {

}
}

會出現
[i j]
1 1
1 2
1 3
1 4
1 5
1 6
2 1
2 2
2 3
...
6 6

(這裡不寫出全部)
但可看出
因為
2顆骰子長的都一樣
上面沒編號或記號 來做區別
所以
1 2 = 2 1
因此可以說 1 2 出現了兩次(或說 2 1 出現了兩次,但還是用 1 2 來講會比較好)

所以
Q:各種組合出現的次數
A:要設計一組記錄次數用的 三維陣列
num[i , j , 0]
每運算一次就加一
num[i , j , 0] = num[i , j , 0] + 1

但為了處理 1 2 = 2 1 的情形修改成
如果 num[j , i , 0] >= 1
則是 num[i , j , 0] = num[i , j , 0] + 1

最後對 num[i , j , 0] >= 1 才做處理
(所謂的處理就是您問的第 1、2、3、4 問題)

比如
"各種組合出現的次數"
for(i=1;i<=6;i++) {
for(j=1;j<=6;j++) {
if(num[i , j , 0] >= 1){
printf("%d %d 出現%d次",i,j,num[i , j , 0]);
}
}
}


比較少寫 C 所以沒寫出完整的程式碼
剩下的實現也交給版友自己發揮了
祝你好運~
mini 目前離線  
送花文章: 2013, 收花文章: 8002 篇, 收花: 26806 次
回覆時引用此帖