史萊姆論壇

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

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

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

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

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2005-07-27, 10:48 PM   #1
kcfs983
註冊會員
榮譽勳章

勳章總數
UID - 12955
在線等級: 級別:0 | 在線時長:0小時 | 升級還需:5小時
註冊日期: 2002-12-16
VIP期限: 2006-02
文章: 72
精華: 0
預設 有人可以幫我解題(C++)嗎~謝謝

用C++寫出
1:移除一字串的頭跟尾的所有空白
2:將字串中一個以上的連續空白以單一空白來取代
3:把1.2的功能併在一起

PS:可以的話這題也幫幫忙@@
1:輸出一對骰子各種組合出現的次數
2:輸出一對骰子各種組合出現的頻率
3:輸出一對骰子各種總合(2.3.4.....12)的次數
4:輸出一對骰子各種總合(2.3.4.....12)的頻率

麻煩會C++的大大幫忙了~~感恩
kcfs983 目前離線  
送花文章: 0, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
舊 2005-07-28, 05:10 AM   #2 (permalink)
註冊會員
 
snoopy 的頭像
榮譽勳章
UID - 33737
在線等級: 級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時級別:49 | 在線時長:2676小時 | 升級還需:24小時
註冊日期: 2003-02-02
VIP期限: 2011-06
住址: 台南共和國
文章: 1831
精華: 0
現金: 12744 金幣
資產: 12834 金幣
預設

#include <stdio.h>

main()
{
int i,j=0,flag=0;
char string[100],stringCopy[100];
printf("輸入字串");
gets(string);
printf("%s\n",string);

for(i=0;i<100 && string[i]!='\0';i++)
{
if(i!=0)
{
if(string[i]!=' ')
{
if(string[i-1]== ' ' && j!=0)
{
stringCopy[j++] = ' ';
stringCopy[j++] = string[i];
}
else
{
stringCopy[j++] = string[i];
}
}
}
else
{
if(string[i]!=' ')
{
stringCopy[j++] = string[i];
}
}
}
printf("%d\n",j);
stringCopy[j]='\0';
printf("<%s>",stringCopy);
}

/*第二提我看不太董意思*/
snoopy 目前離線  
送花文章: 623, 收花文章: 392 篇, 收花: 1288 次
回覆時引用此帖
舊 2005-07-28, 08:56 AM   #3 (permalink)
註冊會員
榮譽勳章

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

嗯嗯~~感謝喔~~
第2題的意思是骰子不是有1~6嗎~就是就2顆骰子1~6的各種組合
例如:骰10次~2顆骰子加起來多少~會出現的跟次數
kcfs983 目前離線  
送花文章: 0, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
舊 2005-07-28, 01:33 PM   #4 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:97 | 在線時長:9858小時 | 升級還需:138小時級別:97 | 在線時長:9858小時 | 升級還需:138小時級別:97 | 在線時長:9858小時 | 升級還需:138小時級別:97 | 在線時長:9858小時 | 升級還需:138小時級別:97 | 在線時長:9858小時 | 升級還需:138小時級別:97 | 在線時長:9858小時 | 升級還需:138小時級別:97 | 在線時長:9858小時 | 升級還需:138小時
註冊日期: 2002-12-07
文章: 13341
精華: 0
現金: 26444 金幣
資產: 3024304 金幣
預設

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

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, 收花文章: 8001 篇, 收花: 26805 次
回覆時引用此帖
舊 2005-07-28, 01:54 PM   #5 (permalink)
註冊會員
榮譽勳章

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

嗯嗯~~謝嚕~~幫了我很大的忙
kcfs983 目前離線  
送花文章: 0, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
發文 回覆



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

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


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


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


SEO by vBSEO 3.6.1