C語(yǔ)言實(shí)現(xiàn)經(jīng)典24點(diǎn)紙牌益智游戲
一、常見(jiàn)游戲規(guī)則
從撲克中每次取出4張牌。使用加減乘除,第一個(gè)能得出24者為贏。(其中,J代表11,Q代表12,K代表13,A代表1),按照要求編程解決24點(diǎn)游戲。
基本要求: 隨機(jī)生成4個(gè)代表?yè)淇伺婆泼娴臄?shù)字字母,程序自動(dòng)列出所有可能算出24的表達(dá)式,用擅長(zhǎng)的語(yǔ)言(C/C++/Java或其他均可)實(shí)現(xiàn)程序解決問(wèn)題。
1.程序風(fēng)格良好(使用自定義注釋模板)
2.列出表達(dá)式無(wú)重復(fù)。
二、具體代碼
#include<iostream>
#include<stdlib.h>
#include<math.h>
#include<time.h>
using namespace std;
int m; //用來(lái)標(biāo)志能否運(yùn)算出24
double arithmetic(int flag,float m,float n) //進(jìn)行四則運(yùn)算
{
switch(flag) //判斷運(yùn)算符號(hào),返回相對(duì)應(yīng)的運(yùn)算結(jié)果
{
case 0:
return (m+n);
case 1:
return (m-n);
case 2:
return (m*n);
case 3:
if (n==0)
return 10000; //除數(shù)為0,則返回10000,使之不能運(yùn)算出24
else
return (m/n);
case 4:
return (n-m);
case 5:
if (m==0)
return 10000; //除數(shù)為0,則返回10000,使之不能運(yùn)算出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確定輸出的運(yùn)算符號(hào)
{
char sign[6]; //定義運(yùn)算符號(hào)數(shù)組
sign[0]='+';
sign[1]='-';
sign[2]='*';
sign[3]='/';
sign[4]='-'; //減法不符合交換律
sign[5]='/'; //除法不符合交換律
if (type==1) //根據(jù)括號(hào)的類(lèi)型做不同的輸出
{
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)行加、減、乘、除運(yùn)算
{
int i,j,k;
float sum1,sum2,sum3; //儲(chǔ)存 3 次兩兩運(yùn)算的結(jié)果
for (i=0; i<4; i++) // "+ - * /" 4個(gè)運(yùn)算符號(hào)選3個(gè),有4*4*4=64種
for (j=0; j<6; j++) // 3種運(yùn)算符排列 有 3!=6 種
for (k=0; k<6; k++)
{
if ((!(i==3 && b==0)) && (!(j==3 && c==0)) && (!(k==3 && d==0))) // 括號(hào)的類(lèi)型為(())
{// 3為做除法運(yùn)算的標(biāo)志,除數(shù)為 0 時(shí),跳過(guò) = =
sum1=arithmetic(i,a,b); //a,b做 以 i 為標(biāo)志的運(yùn)算,然后把值賦給sum1
sum2=arithmetic(j,sum1,c); //sum1,c做 以 j 為標(biāo)志的運(yùn)算,然后把值賦給sum2
sum3=arithmetic(k,sum2,d); //sum2,d做 以 k 為標(biāo)志的運(yùn)算,然后把值賦給sum3
if (fabs(sum3-24)<0.001)//判斷能否運(yùn)算出24,出現(xiàn)小數(shù)時(shí),能夠包含在內(nèi)
{
m++; //標(biāo)志能運(yùn)算出24
show(1,i,j,k,a,b,c,d); // 輸出運(yùn)算出 24 的表達(dá)式
}
}
if (k==2)// ()*()
{
sum1=arithmetic(i,a,b); //a,b做 以 i 為標(biāo)志的運(yùn)算,然后把值賦給sum1
sum2=arithmetic(j,c,d); //sum1,c做 以 j 為標(biāo)志的運(yùn)算,然后把值賦給sum2
sum3=sum1*sum2;
if (fabs(sum3-24)<0.001)//出現(xiàn)小數(shù)時(shí),能夠包含在內(nèi)
{
m++; //標(biāo)志能運(yùn)算出24
show(2,i,j,k,a,b,c,d); // 輸出運(yùn)算出 24 的表達(dá)式
}
}
if (k==3)// 括號(hào)的類(lèi)型為()()
{
sum1=arithmetic(i,a,b); //sum1,c做 以 j 為標(biāo)志的運(yùn)算,然后把值賦給sum2
sum2=arithmetic(j,c,d); //sum1,c做 以 j 為標(biāo)志的運(yùn)算,然后把值賦給sum2
if (sum2!=0)
{
sum3=sum1/sum2;
if (fabs(sum3-24)<0.001)//出現(xiàn)小數(shù)時(shí),能夠包含在內(nèi)
{
m++; //標(biāo)志能運(yùn)算出24
show(3,i,j,k,a,b,c,d); // 輸出運(yùn)算出 24 的表達(dá)式
}
}
}
}
}
int main() //主函數(shù)
{
int y;
int i,j,k,l;
srand((unsigned)time(0));
int a[4]; //儲(chǔ)存所輸入的 4個(gè) 整數(shù)
{
cout<< "******************************24點(diǎn)游戲*******************************"<<endl<<endl;
cout<<"請(qǐng)輸入選項(xiàng):0、隨機(jī)生成數(shù)字 1、離開(kāi)游戲"<<endl;
cin>>y ; //輸入選項(xiàng)
while(true)
{
if(y==0)
{
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<< "等你回來(lái)哦!"<<endl;
return 0;
}
}
for (i=0; i<4; i++)//4的排列 4!=24,每中情況調(diào)用calculate
for (j=0; j<4; j++)
if (j!=i)//第2數(shù)和第1個(gè)數(shù)不能重復(fù)
for (k=0; k<4; k++)
if (k!=j && k!=i) //第3數(shù)和第1,2個(gè)數(shù)不能重復(fù)
for (l=0; l<4; l++)
if (l!=i && l!=j && l!=k) //第4數(shù)和第1,2,3個(gè)數(shù)不能重復(fù)
{
calculate(a[i],a[j],a[k],a[l]);//調(diào)用calculate函數(shù),進(jìn)行進(jìn)行加、減、乘、除運(yùn)算
}
}
return 0;
}
三、測(cè)試截圖


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語(yǔ)言實(shí)現(xiàn)撲克牌計(jì)算24點(diǎn)
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易撲克牌游戲
- 使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子的點(diǎn)數(shù)問(wèn)題
- C語(yǔ)言實(shí)現(xiàn)洗牌發(fā)牌小程序
- C語(yǔ)言實(shí)現(xiàn)自動(dòng)發(fā)牌程序
- C語(yǔ)言實(shí)現(xiàn)隨機(jī)發(fā)牌
- C語(yǔ)言編寫(xiě)洗牌發(fā)牌程序
- C語(yǔ)言實(shí)現(xiàn)紙牌24點(diǎn)小游戲
- C語(yǔ)言實(shí)現(xiàn)紙牌計(jì)算24點(diǎn)小游戲
- C語(yǔ)言實(shí)現(xiàn)隨機(jī)發(fā)撲克牌
相關(guān)文章
C++項(xiàng)目實(shí)戰(zhàn)之makefile使用
這篇文章主要介紹了C++項(xiàng)目實(shí)戰(zhàn)之makefile使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05
C++詳細(xì)實(shí)現(xiàn)紅黑樹(shù)流程詳解
今天我要跟大家介紹二叉搜索樹(shù)中的另一顆樹(shù)——紅黑樹(shù),它主要是通過(guò)控制顏色來(lái)控制自身的平衡,但它的平衡沒(méi)有AVL樹(shù)的平衡那么嚴(yán)格2022-06-06
Visual Studio調(diào)試C/C++教程指南
VisualStudio是微軟開(kāi)發(fā)的一款集成開(kāi)發(fā)環(huán)境軟件,本文主要介紹了Visual Studio調(diào)試C/C++教程指南,熟悉地掌握基于VS的C/C++調(diào)試技術(shù),可以大幅提升調(diào)試性能,感興趣的可以了解一下2024-06-06
vscode終端中打不開(kāi)conda虛擬包管理的解決
本文主要介紹了vscode終端中打不開(kāi)conda虛擬包管理的解決,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-09-09
C語(yǔ)言實(shí)現(xiàn)計(jì)算雙色球的中獎(jiǎng)率
這篇文章主要為大家詳細(xì)介紹了如何利用C語(yǔ)言實(shí)現(xiàn)計(jì)算雙色球的中獎(jiǎng)率,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-12-12
C語(yǔ)言中的pause()函數(shù)和alarm()函數(shù)以及sleep()函數(shù)
這篇文章主要介紹了C語(yǔ)言中的pause()函數(shù)和alarm()函數(shù)以及sleep()函數(shù),是C語(yǔ)言入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09

