日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

称硬币

發(fā)布時(shí)間:2023/12/18 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 称硬币 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

枚舉算法——稱硬幣

枚舉算法:核心思想就是枚舉所有的可能,本質(zhì)是從所有的候選答案中去搜索正確的解,使用該算法要滿足兩個(gè)條件:
(1)可預(yù)先確定候選答案的數(shù)量;
(2)候選答案的范圍在求解之前必須要有一個(gè)確定的集合。

優(yōu)點(diǎn):算法簡單,在局部地方使用枚舉法,效果十分的好;
缺點(diǎn):運(yùn)算量過大,當(dāng)問題規(guī)模變大的時(shí)候,循環(huán)的階數(shù)越大,執(zhí)行速度越慢。

問題描述:

賽利有12枚銀幣。其中有11枚真幣和1枚假幣。假幣看起來和真幣沒有區(qū)別,但是重量不同。但賽利不知道假幣比真幣輕還是重。于是他向朋友借了一架天平。朋友希望賽利稱三次就能找出假幣并且確定假幣是輕是重。例如:如果賽利用天平稱兩枚硬幣,發(fā)現(xiàn)天平平衡,說明兩枚都是真的。如果賽利用一枚真幣與另一枚銀幣比較,發(fā)現(xiàn)它比真幣輕或重,說明它是假幣。經(jīng)過精心安排每次的稱量,賽利保證在稱三次后確定假幣。

輸入

第一行有一個(gè)數(shù)字n,表示有n組測試用例。
對(duì)于每組測試用例:
輸入有三行,每行表示一次稱量的結(jié)果。賽利事先將銀幣標(biāo)號(hào)為A-L。每次稱量的結(jié)果用三個(gè)以空格隔開的字符串表示:天平左邊放置的硬幣 天平右邊放置的硬幣 平衡狀態(tài)。其中平衡狀態(tài)用up'',down’’, 或 ``even’'表示, 分別為右端高、右端低和平衡。天平左右的硬幣數(shù)總是相等的。

輸出

輸出哪一個(gè)標(biāo)號(hào)的銀幣是假幣,并說明它比真幣輕還是重(heavy or light)。

Sample input

1
ABCD EFGH even
ABCI EFJK up
ABIJ EFGH even

Sample Output

K is the counterfeit coin and it is light

思路:

A-L中每個(gè)都有兩種可能,是假幣或不是假幣,一共就有12x2=24種

#include<stdio.h> #include<string.h> char left[3][7],right[3][7]; char result[3][5]; int heavy(char c){int i;for(i=0;i<3;i++){switch(result[i][0]){case 'e':if(strchr(left[i],c)!=NULL||strchr(right[i],c)!=NULL) return 0;break;case 'u':if(strchr(left[i],c)==NULL) return 0;break;case 'd':if(strchr(right[i],c)==NULL) return 0;break;}}return 1;} int light(char c) {int i;for(i=0;i<3;i++){switch(result[i][0]){case 'e':if(strchr(left[i],c)!=NULL||strchr(right[i],c)!=NULL) return 0;break;case 'u':if(strchr(right[i],c)==NULL) return 0;break;case 'd':if(strchr(left[i],c)==NULL) return 0;break;}}return 1; } int main() {int i,k,n;char c; scanf("%d",&n);for(k=0;k<n;k++){for(i=0;i<3;i++)scanf("%s %s %s",&left[i],&right[i],&result[i]); for(c='A';c<='L';c++){ if(heavy(c)){printf("%c is the counterfeit coin and it is heavy.\n",c);break;}if(light(c)){printf("%c is the counterfeit coin and it is light.\n",c);break;}}}return 0; }

總結(jié)

以上是生活随笔為你收集整理的称硬币的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。