找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
尊貴會員無限觀看附件圖片伊莉需要你的贊助和支持搞笑、娛樂、精彩的影片讓你看
gecosplaymg自慰adobe流出
ntr侵蝕のヒrenee unarmy of 四合院:湿った肌ダンジョ

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

[繁]迷宮飯 - 15

在店內買個飲料也會出

(4月新番)[繁]格林童

[繁]無職轉生 第二季1

[繁]轉生貴族憑鑑定技

晴天 體驗台灣特色檳
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 3830|回復: 8
打印上一主題下一主題

找零錢[複製鏈接]

帖子
146
積分
0 點
潛水值
19693 米
跳轉到指定樓層
樓主
發表於 2008-1-11 11:59 PM|只看該作者|倒序瀏覽
有哪位大大可以幫忙嗎? 能告訴我原理或是如何做嗎?

試寫出一個模擬換零錢的程式:
只可以接受紙鈔(100,200,500,1000)
可以選擇零錢面額(一元、五元、十元、五十元)以及個數
剩下的金額以最少的零錢數找出(假設要以100元戶10個一元,結果會出來10個一元與9個十元)
分享分享0收藏收藏0支持支持0
若對尊貴或贊助會員有任何疑問,歡迎向我們查詢。我們的即時通或MSN: admin@eyny.com

使用道具檢舉

小鬼魚 該用戶已被刪除
頭香
發表於 2008-1-12 01:32 AM|只看該作者
剩下以最少零錢數找出...
那應該會找出 一個五十元 跟 四個十元吧???
是我會錯意了嗎??
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。

使用道具檢舉

帖子
0
積分
2 點
潛水值
360 米
3
發表於 2008-1-12 01:50 AM|只看該作者
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
假設要以100元戶10個一元,結果會出來10個一元與9個十元

這應該不太對= =
100  = (1*10) + (50*1) + (10*4)
只要14個就夠了
輸入格式:
[總額] [面額] [個數]
輸入範例:
100 1 10
輸出範例:
1: 10
5: 0
10: 4
50: 1
原理寫在註解裡面
  1. #include<iostream>
  2. using namespace std;
  3. int main(){
  4.   int n, c[]={1,5,10,50}, p[51], v, vn;
  5.   for(int i = 0;i < 4;i++)
  6.    p[c[i]] = i;  //拿來放位置,咖方便
  7.   while(cin >> n >> v >> vn){
  8.   int m = 3, cc[4]={0}; //cc[]拿來存結果
  9.                //m為目前最大值在c[]中的位置
  10.     n -= v*vn; //先把總額去掉一定要拿找的錢
  11.     cc[p[v]] += vn;  //p[]派上用場了 XD
  12.     while(n > 0 && m >= 0){ //當還有剩下時繼續做
  13.                   //m>=0避免超出範圍 (其實如果輸入都符合規定的話,是不需要的)
  14.     if(n/c[m] > 0){ //也可以寫成 n >= c[m]  
  15.       cc[m] += (n / c[m]);
  16.     n %= c[m];
  17.     }else
  18.       m--; //剛開始是最大值的位置,如果 n < c[m],則往前(即變小)
  19.   }
  20.   
  21.   //輸出
  22.   for(int i = 0;i < 4;i++){
  23.       cout << c[i] << ": " << cc[i] << endl;   
  24.   }
  25.   cout << endl;
  26.   }
  27.   system("pause");
  28.   return 0;
  29. }
複製代碼

這個方法一般稱為貪婪法(Greedy)
只要想成每次都取最好的答案就夠了
是一種很簡單的演算法
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
...
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

小鬼魚 該用戶已被刪除
4
發表於 2008-1-12 02:03 AM|只看該作者
@@...高手呢!!!
想不到有這樣的寫法!!!
p[c]= i;....可以問依下這段的用意嗎??

基本上是看不懂這樣的寫法@@  SORRY

[ 本帖最後由 小鬼魚 於 2008-1-12 02:05 AM 編輯 ]
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。

使用道具檢舉

帖子
0
積分
2 點
潛水值
360 米
5
發表於 2008-1-12 02:26 AM|只看該作者
其實只是個小技巧
從頭到尾只用在
cc[p[v]] += vn;

因為已經先把v*vn減掉了
所以要先把結果加進去

而設p是為了增加效率(其實是懶XD)
cc[p[v]] += vn;
直接取v在c中的位置,不用再search一遍




所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。

使用道具檢舉

帖子
146
積分
0 點
潛水值
19693 米
6
發表於 2008-1-12 10:44 AM|只看該作者

回復 #3 safestation 的帖子

大大真是厲害!! 雖然我還是不太懂 但是謝謝你的指導囉^^

其實很多地方我沒學過 但是我會慢慢研究的~

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
113
積分
1990 點
潛水值
25545 米
7
發表於 2008-1-12 04:55 PM|只看該作者
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
原帖由 safestation 於 2008-1-12 02:26 AM 發表
其實只是個小技巧
從頭到尾只用在
cc] += vn;

因為已經先把v*vn減掉了
所以要先把結果加進去

而設p是為了增加效率(其實是懶XD)
cc] += vn;
直接取v在c中的位置,不用再search一遍


Greedy演算法的確可解決部分問題,像這個例子!

...
瀏覽完整內容,請先 註冊登入會員
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。

使用道具檢舉

星宿少爺 該用戶已被刪除
8
發表於 2008-1-12 09:05 PM|只看該作者
試寫出一個模擬換零錢的程式:
只可以接受紙鈔(100,200,500,1000)
可以選擇零錢面額(一元、五元、十元、五十元)以及個數
剩下的金額以最少的零錢數找出(假設要以100元戶10個一元,結果會出來10個一元與9個十元)

以下是小弟的想法,再接受紙鈔這個地方應該用IF判斷就可以解決了;
當條件滿足妳上述的(100,200,500,1000)才往下做換幣動作,
...
瀏覽完整內容,請先 註冊登入會員
若瀏覽伊莉的時侯發生問題或不正常情況,請使用Internet Explorer(I.E)。

使用道具檢舉

小鬼魚 該用戶已被刪除
9
發表於 2008-1-13 02:55 PM|只看該作者
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

回復 #5 safestation 的帖子

差不多看懂了一低低....
一個簡單的程式要寫的很好還蠻難的呢!!!

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部