NYOJ 721 纸牌游戏 简单题
生活随笔
收集整理的這篇文章主要介紹了
NYOJ 721 纸牌游戏 简单题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
紙牌游戲CF
時間限制:1000?ms ?|? 內存限制:65535?KB 難度:1 描述-
玩家1和玩家2各出一張牌,看誰大。如果兩張牌都不是王牌花色或則都是王牌花色,則牌面大的牌大,如果牌面一樣大則一樣大。若其中一張牌是王牌而另一張不是,則無論牌面如何都是王牌花色大。
對于每組數據,首先輸入一個字符(S\H\D\C),表示王牌花色。
接下去一行有兩張牌面,表示為牌面花色,如8D、9S等。
第一次寫的較長的代碼:
#include<stdio.h> #include<string.h> int main() {int n,t,m,len1,len2;char s1[5],s2[5],ch;scanf("%d",&t);getchar();while(t--){scanf("%c",&ch);getchar();scanf("%s %s",s1,s2);len1=strlen(s1);len2=strlen(s2);if(len1==3) m=10;else if(len1==2){if(s1[0]>='2'&&s1[0]<='9')m=s1[0]-'0';else if(s1[0]=='A') m=1;else if(s1[0]=='J') m=11;else if(s1[0]=='Q') m=12;else if(s1[0]=='K') m=13;}if(len2==3) n=10;else if(len2==2){if(s2[0]>='2'&&s2[0]<='9')n=s2[0]-'0';else if(s2[0]=='A') n=1;else if(s2[0]=='J') n=11;else if(s2[0]=='Q') n=12;else if(s2[0]=='K') n=13;}int flag=1;if(len1==3&&len2==3){if(s1[2]==ch&&s2[2]==ch){if(m<=n) flag=0;}else if(s1[2]!=ch&&s2[2]==ch)flag=0;else if(s1[2]!=ch&&s2[2]!=ch){if(m<=n) flag=0;}}else if(len1==3&&len2==2){if(s1[2]==ch&&s2[1]==ch){if(m<=n) flag=0;}else if(s1[2]!=ch&&s2[1]==ch)flag=0;else if(s1[2]!=ch&&s2[1]!=ch){if(m<=n) flag=0;}}else if(len1==2&&len2==3){if(s1[1]==ch&&s2[2]==ch){if(m<=n) flag=0;}else if(s1[1]!=ch&&s2[2]==ch)flag=0;else if(s1[1]!=ch&&s2[2]!=ch){if(m<=n) flag=0;}}else if(len1==2&&len2==2){if(s1[1]==ch&&s2[1]==ch){if(m<=n) flag=0;}else if(s1[1]!=ch&&s2[1]==ch)flag=0;else if(s1[1]!=ch&&s2[1]!=ch){if(m<=n) flag=0;}}if(flag) printf("YES\n");else printf("NO\n");getchar();}return 0; }寫完以后覺得可以把這段代碼簡化一下,因為里面有很多一樣的部分,即使不一樣,思想也是一樣的,比如把牌號轉化為十進制數字時可以寫一個函數,判斷花色時只需判斷s1[len1-1]和s2[len2-1]即可,沒有必要分開寫,簡化以后代碼幾乎縮短了一半。
簡化后代碼:
#include<stdio.h> #include<string.h> int n,t,m,len1,len2; char s1[5],s2[5],ch; int find(char *s,int len)/*把牌號轉化為十進制數字*/ {int k;if(len==3) k=10; /*長度為3,牌號肯定是10*/else if(len==2){if(s[0]>='2'&&s[0]<='9')k=s[0]-'0';else if(s[0]=='A') k=1;else if(s[0]=='J') k=11;else if(s[0]=='Q') k=12;else if(s[0]=='K') k=13;}return k; } int main() {scanf("%d",&t);getchar();while(t--){scanf("%c",&ch); /*王牌花色*/getchar();scanf("%s %s",s1,s2);len1=strlen(s1);len2=strlen(s2);m=find(s1,len1);n=find(s2,len2);int flag=1;if(s1[len1-1]==ch&&s2[len2-1]==ch) /*兩張牌都是王牌花色*/{if(m<=n) flag=0;} /*注意這個大括號不能少*/else if(s1[len1-1]!=ch&&s2[len2-1]==ch) /*第一張不是,第二張是王牌花色*/flag=0;else if(s1[len1-1]!=ch&&s2[len2-1]!=ch) /*都不是王牌花色*/{if(m<=n) flag=0;}if(flag) printf("YES\n");else printf("NO\n");getchar();}return 0; }里面需要注意的是大括號和getchar()的運用,多一個少一個結果就會不一樣,要仔細思考。總結
以上是生活随笔為你收集整理的NYOJ 721 纸牌游戏 简单题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2年6个月11天,外包到阿里的修仙之路
- 下一篇: NYOJ 240 小明的调查统计(二)