C語言實現(xiàn)紙牌計算24點小游戲
利用系統(tǒng)時間設定隨機種子生成4個隨機數(shù),并對4個數(shù)字之間的運算次序以及運算符號進行枚舉,從而計算判斷是否能得出24,以達到程序目的。程序主要功能已完成,目前還有部分細節(jié)未處理,待完成ing...對于代碼中的錯誤,懇請批評指正。
游戲描述:
A-10:分別代表數(shù)字 1-10。
J,Q,K:均代表數(shù)字1。
考慮到部分地方的規(guī)則,J,Q,K 也可以當成10 ,或者直接代表本身所代表的數(shù)字,即11、12、13來運算。
使用加減乘除,能得出24者為贏,存在無解情況。
游戲開始得分為1000分,每一秒鐘減少1分,當答對一次時,分數(shù)增加100分。(暫未實現(xiàn))
代碼展示:
/* * * Project : 計算24 * * Date : 2015年3月25日10:55:47 * * Remark :紙牌中的10以0代替,減法得數(shù)均為正數(shù) */ #include <stdio.h> #include <stdlib.h> #include <math.h> #include <time.h> char getPokerCard(int value) { if(value==1) { return 'A'; } else if(value<10) { return value+'0'; } else if(value==10) { return '0'; } else if(value==11) { return 'J'; } else if(value==12) { return 'Q'; } else if(value==13) { return 'K'; } } void printAnswer(int flag,int *poker,char *oper,char *answer) { char a=getPokerCard(poker[0]); char b=getPokerCard(poker[1]); char c=getPokerCard(poker[2]); char d=getPokerCard(poker[3]); switch(flag) { //1.((A*B)*C)*D case 1: printf("((%c%c%c)%c%c)%c%c\n",a,oper[0],b,oper[1],c,oper[2],d); break; //2.(A*(B*C))*D case 2: printf("(%c%c(%c%c%c))%c%c\n",a,oper[0],b,oper[1],c,oper[2],d); break; //3.(A*B)*(C*D) case 3: printf("(%c%c%c)%c(%c%c%c)\n",a,oper[0],b,oper[1],c,oper[2],d); break; //4.A*(B*(C*D)) case 4: printf("%c%c(%c%c(%c%c%c))\n",a,oper[0],b,oper[1],c,oper[2],d); break; //5.A*((B*C)*D) case 5: printf("%c%c((%c%c%c)%c%c)\n",a,oper[0],b,oper[1],c,oper[2],d); break; default: break; } //存儲answer return ; } double getValue(double num1,double num2,char oper) { double result; switch(oper) { case '+': result=num1+num2; break; case '-': result=fabs(num1-num2); break; case '*': result=num1*num2; break; case '/': result=num1/num2; break; default : break; } return result; } int getResult(int *poker,char *oper,char *answer) { double t; //將計算值取到 int a=poker[0]>10?1:poker[0]; int b=poker[1]>10?1:poker[1]; int c=poker[2]>10?1:poker[2]; int d=poker[3]>10?1:poker[3]; //窮舉運算次序 //1.((A*B)*C)*D t=0; t=getValue(a,b,oper[0]); t=getValue(t,c,oper[1]); t=getValue(t,d,oper[2]); if(fabs(t-24)<0.0001) { printAnswer(1,poker,oper,answer); return 1; } //2.(A*(B*C))*D t=0; t=getValue(b,c,oper[1]); t=getValue(a,t,oper[0]); t=getValue(t,d,oper[2]); if(fabs(t-24)<0.0001) { printAnswer(2,poker,oper,answer); return 1; } //3.(A*B)*(C*D) t=0; t=getValue(getValue(a,b,oper[0]),getValue(c,d,oper[2]),oper[1]); if(fabs(t-24)<0.0001) { printAnswer(3,poker,oper,answer); return 1; } //4.A*(B*(C*D)) t=0; t=getValue(c,d,oper[2]); t=getValue(b,t,oper[1]); t=getValue(a,t,oper[0]); if(fabs(t-24)<0.0001) { printAnswer(4,poker,oper,answer); return 1; } //5.A*((B*C)*D) t=0; t=getValue(b,c,oper[1]); t=getValue(t,d,oper[2]); t=getValue(a,t,oper[0]); if(fabs(t-24)<0.0001) { printAnswer(5,poker,oper,answer); return 1; } return 0; } void printResult(int *poker,char *answer) { char OperKey[4]={'+','-','*','/'}; char oper[3]; int i,j,k; int count=0; for(i=0;i<4;i++) for(j=0;j<4;j++) for(k=0;k<4;k++) { oper[0]=OperKey[i]; oper[1]=OperKey[j]; oper[2]=OperKey[k]; if(getResult(poker,oper,answer)) count++; } if(count) { printf("共%d種解法\n",count); } else { printf("該情況無解\n"); } return ; } void printPoker(int *poker) { int i; for(i=0;i<4;i++) { printf("%c ",getPokerCard(poker[i])); } printf("\n"); return ; } void getRandomPokers(int *poker) { int i; //利用系統(tǒng)時間作為種子產(chǎn)生隨機數(shù) ,函數(shù)srand(),rand()=>stdlib.h ,函數(shù)time()=>time.h srand((unsigned)time(NULL)); for(i=0;i<4;i++) { poker[i]=rand()%12+1; } return ; } main() { int poker[4]; char answer[20]; char c; printf("紙牌計算24點\n--------------------------------------------\n"); do { //生成隨機紙牌 getRandomPokers(poker); printf("隨機生成的紙牌為:\n"); //輸出生成的紙牌 printPoker(poker); printf("\n任意鍵獲得結果...\n"); getchar(); //輸出計算結果 printResult(poker,answer); printf("\n回車鍵繼續(xù),其他鍵并回車退出...\n"); c=getchar(); printf("--------------------------------------------\n"); } while(c=='\n'); return 0; }
效果展示
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
C++中template方法undefined reference to的問題解決
Undefined reference to 錯誤:這類錯誤是在連接過程中出現(xiàn)的,本文就來介紹一下C++中template方法undefined reference to的問題解決,具有一定的參考價值,感興趣的可以了解一下2024-03-03