這篇文章主要介紹C語言中如何實現(xiàn)紙牌24點小游戲,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)服務(wù)項目包括館陶網(wǎng)站建設(shè)、館陶網(wǎng)站制作、館陶網(wǎng)頁制作以及館陶網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,館陶網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到館陶省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
本文實例為大家分享了C語言紙牌24點小游戲的具體實現(xiàn)代碼,供大家參考,具體內(nèi)容如下
此程序參考C語言實現(xiàn)經(jīng)典24點紙牌益智游戲,并做出一些改進(jìn)。
一、題目要求:
24點游戲規(guī)則:
從撲克中每次取出4張牌。使用加減乘除,第一個能得出24者為贏。(其中,J代表11,Q代表12,K代表13,A代表1),按照要求編程解決24點游戲。
基本要求:
隨機(jī)生成4個代表撲克牌牌面的數(shù)字字母,程序自動列出所有可能算出24的表達(dá)式,用擅長的語言(C/C++/Java或其他均可)實現(xiàn)程序解決問題。
1.程序風(fēng)格良好(使用自定義注釋模板)
2.列出表達(dá)式無重復(fù)。
二、算法思路:
通過隨機(jī)函數(shù)隨機(jī)產(chǎn)生1到13之間的4個數(shù);
對這四個數(shù)分三次進(jìn)行四則運算,并在每次運算完成后給表達(dá)式加上括號,避免運算順序?qū)е逻\算值錯誤;
若滿足結(jié)果等于24,則輸出表達(dá)式。
三、調(diào)試及測試截屏:
程序運行后出現(xiàn)小數(shù)減大數(shù),使實際結(jié)果為負(fù)的情況

調(diào)試:

調(diào)試發(fā)現(xiàn)在四則運算減法這塊沒有對減數(shù)與被減數(shù)的大小進(jìn)行約束,在加上條件判斷后正確

運行結(jié)果:

四、程序?qū)崿F(xiàn):
#include<iostream>
#include<stdlib.h>
#include<math.h>
#include<time.h>
using namespace std;
int m; //用來標(biāo)志能否運算出24
double arithmetic(int flag,float m,float n) //進(jìn)行四則運算
{
switch(flag) //判斷運算符號,返回相對應(yīng)的運算結(jié)果
{
case 0:
return (m+n);
case 1:
if(m>n)
return (m-n);
else
return 10000;//減數(shù)大于被減數(shù),則返回10000,使之不能運算出24
case 2:
return (m*n);
case 3:
if (n==0)
return 10000; //除數(shù)為0,則返回10000,使之不能運算出24
else
return (m/n);
case 4:
if(n>m)
return (n-m);
else
return 10000;//減數(shù)大于被減數(shù),則返回10000,使之不能運算出24
case 5:
if (m==0)
return 10000; //除數(shù)為0,則返回10000,使之不能運算出24
else
return (n/m);
default:
return 0;
}
}
void show(int type,int i,int j,int k,float a,float b,float c,float d)//利用參數(shù)type選擇輸出形式,利用參數(shù)i,j,k確定輸出的運算符號
{
char sign[6]; //定義運算符號數(shù)組
sign[0]='+';
sign[1]='-';
sign[2]='*';
sign[3]='/';
sign[4]='-'; //減法不符合交換律
sign[5]='/'; //除法不符合交換律
if (type==1) //根據(jù)括號的類型做不同的輸出
{
if(j==4 || j==5) //減法和除法
{
if (k==4 || k==5) // a*(b*(c+d)) 形式
cout<<d<<sign[k]<<"("<<c<<sign[j]<<"("<<a<<sign[i]<<b<<")) = 24 "<<endl;
else // (a*(b+c))*d 形式
cout<<"("<<c<<sign[j]<<"("<<a<<sign[i]<<b<<"))"<<sign[k]<<d<<" = 24"<<endl;
}
else if (k==4 || k==5)// a*((b+c)*d) 形式
{
cout<<d<<sign[k]<<"(("<<a<<sign[i]<<b<<")"<<sign[j]<<c<<") = 24"<<endl;
}
else // ((a+b)*c)*d 形式
cout<<"(("<<a<<sign[i]<<b<<")"<<sign[j]<<c<<")"<<sign[k]<<d<<"= 24"<<endl;
}
if (type==2 || type==3)// (a+b)*(c+d) 形式
{
cout<<"("<<a<<sign[i]<<b<<")"<<sign[k]<<"("<<c<<sign[j]<<d<<")= 24"<<endl;
}
}
void calculate(float a,float b,float c,float d) //進(jìn)行加、減、乘、除運算
{
int i,j,k;
float sum1,sum2,sum3; //儲存 3 次兩兩運算的結(jié)果
for (i=0; i<4; i++) // "+ - * /" 4個運算符號選3個,有4*4*4=64種
for (j=0; j<6; j++) // 3種運算符排列 有 3!=6 種
for (k=0; k<6; k++)
{
if ((!(i==3 && b==0)) && (!(j==3 && c==0)) && (!(k==3 && d==0)))
{// 3為做除法運算的標(biāo)志,除數(shù)為 0 時,跳過
sum1=arithmetic(i,a,b); //a,b做 以 i 為標(biāo)志的運算,然后把值賦給sum1
sum2=arithmetic(j,sum1,c); //sum1,c做以j為標(biāo)志的運算,然后把值賦給sum2
sum3=arithmetic(k,sum2,d); //sum2,d做以k為標(biāo)志的運算,然后把值賦給sum3
if (fabs(sum3-24)<0.001)//判斷能否運算出24,出現(xiàn)小數(shù)時,能夠包含在內(nèi)
{
m++; //標(biāo)志能運算出24
show(1,i,j,k,a,b,c,d); //輸出運算出 24 的表達(dá)式
}
}
if (k==2)// ()*()
{
sum1=arithmetic(i,a,b); //a,b做 以i為標(biāo)志的運算,然后把值賦給sum1
sum2=arithmetic(j,c,d); //sum1,c做以j為標(biāo)志的運算,然后把值賦給sum2
sum3=sum1*sum2;
if (fabs(sum3-24)<0.001)//出現(xiàn)小數(shù)時,能夠包含在內(nèi)
{
m++; //標(biāo)志能運算出24
show(2,i,j,k,a,b,c,d); // 輸出運算出24的表達(dá)式
}
}
if (k==3)
{
sum1=arithmetic(i,a,b); //sum1,c做以j為標(biāo)志的運算,然后把值賦給sum2
sum2=arithmetic(j,c,d); //sum1,c做以j為標(biāo)志的運算,然后把值賦給sum2
if (sum2!=0)
{
sum3=sum1/sum2;
if (fabs(sum3-24)<0.001)//出現(xiàn)小數(shù)時,能夠包含在內(nèi)
{
m++; //標(biāo)志能運算出24
show(3,i,j,k,a,b,c,d); //輸出運算出24的表達(dá)式
}
}
}
}
}
int main() //主函數(shù)
{
int y;
int i,j,k,l;
srand((unsigned)time(0));
int a[4]; //儲存所產(chǎn)生的4個隨機(jī)數(shù)
{
cout<< "********************24點游戲*********************"<<endl<<endl;
cout<<"請輸入選項:0、開始游戲 1、離開游戲"<<endl;
cin>>y ; //輸入選項
while(true)
{
if(y==0)
{
cout<<"產(chǎn)生隨機(jī)數(shù)為:"<<endl;
for(i=0; i<4; i++)
{
a[i]=rand()%13+1;
}
for(i=0; i<4; i++)
{
cout<<a[i]<<" ";
}
cout<<endl;
break;
}
else
{
cout<< "下次再見!"<<endl;
return 0;
}
}
for (i=0; i<4; i++)
for (j=0; j<4; j++)
if (j!=i)//第2個數(shù)和第1個數(shù)不能重復(fù)
for (k=0; k<4; k++)
if (k!=j && k!=i) //第3個數(shù)和第1,2個數(shù)不能重復(fù)
for (l=0; l<4; l++)
if (l!=i && l!=j && l!=k) //第4個數(shù)和第1,2,3個數(shù)不能重復(fù)
{
calculate(a[i],a[j],a[k],a[l]);//調(diào)用calculate函數(shù),進(jìn)行進(jìn)行加、減、乘、除運算
}
}
return 0;
}以上是“C語言中如何實現(xiàn)紙牌24點小游戲”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
當(dāng)前名稱:C語言中如何實現(xiàn)紙牌24點小游戲
URL地址:http://chinadenli.net/article46/jhpdeg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、標(biāo)簽優(yōu)化、電子商務(wù)、微信小程序、網(wǎng)站導(dǎo)航、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)