称硬币
枚舉算法——稱硬幣
枚舉算法:核心思想就是枚舉所有的可能,本質(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é)
- 上一篇: 【人工翻译线代教材】Introducti
- 下一篇: 500次 “LOVE“的歌词 Taylo