




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第基于C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單五子棋游戲本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單五子棋游戲的具體代碼,供大家參考,具體內(nèi)容如下
五子棋大家都玩兒過(guò),所以規(guī)則就不介紹了
今天遇到一個(gè)學(xué)弟在實(shí)現(xiàn)的時(shí)候遇到一些問(wèn)題,所以將實(shí)現(xiàn)的過(guò)程記錄下
水平有限,僅供參考,互相交流,共同進(jìn)步。
#includestdio.h
#includewindows.h
intmain()
inti,j;//表示棋盤(pán)橫縱坐標(biāo)
/*************************************************
*
*繪制表格需要的字符:┌┬┐├┼┤└┴┘│─●○
*數(shù)組的值0表示黑棋,1表示白棋,2表示該位置沒(méi)有棋
*
*/
intqipan[20][20];
intcolor=0;//0表示黑棋(圓圈),1表示白棋
intiTemp=0,jTemp=0,countTemp=0;
intcolorFlag=0;
charop;
again:
for(i=0;ii++)
for(j=0;jj++)
qipan[i][j]=2;
while(1)
{
printf("請(qǐng)輸入棋子位置(棋盤(pán)大小為20*20),如2,2:");
scanf("%d,%d",i,
if(i1||i20||j1||j20)
{
printf("輸入的位置超出了棋盤(pán)的范圍,請(qǐng)重新輸入!\n");
continue;
}
if((2!=qipan[i-1][j-1]))
{
printf("提示:該位置已經(jīng)有棋子了!\n");
fflush(stdin);
continue;
}
color=(color+1)%2;//獲取棋盤(pán)棋子屬性
qipan[i-1][j-1]=color;//將該位置棋子屬性給棋盤(pán)
//根據(jù)棋盤(pán)對(duì)應(yīng)位置屬性,繪制最新?tīng)顟B(tài)的棋盤(pán),一行行繪制,邊緣特別處理
for(i=1;ii++)
{
//第一行
if(i==1)
{
//第一列
if(qipan[i-1][0]==1)
printf("●");
if(qipan[i-1][0]==0)
printf("○");
if(qipan[i-1][0]==2)
printf("┌");
//第2-19列
for(j=2;jj++)
{
if(qipan[i-1][j-1]==1)
printf("●");
if(qipan[i-1][j-1]==0)
printf("○");
if(qipan[i-1][j-1]==2)
printf("┬");
}
//第20列
if(qipan[i-1][j-1]==1)
printf("●");
if(qipan[i-1][j-1]==0)
printf("○");
if(qipan[i-1][j-1]==2)
printf("┐");
printf("\n");
}
//第2-19行
if(i=19i=2)
{
//第一列
if(qipan[i-1][0]==1)
printf("●");
if(qipan[i-1][0]==0)
printf("○");
if(qipan[i-1][0]==2)
printf("├");
//第2-19列
for(j=2;jj++)
{
if(qipan[i-1][j-1]==1)
printf("●");
if(qipan[i-1][j-1]==0)
printf("○");
if(qipan[i-1][j-1]==2)
printf("┼");
}
//第20列
if(qipan[i-1][j-1]==1)
printf("●");
if(qipan[i-1][j-1]==0)
printf("○");
if(qipan[i-1][j-1]==2)
printf("┤");
printf("\n");
}
//第20行
if(i==20)
{
if(qipan[i-1][0]==1)
printf("●");
if(qipan[i-1][0]==0)
printf("○");
if(qipan[i-1][0]==2)
printf("└");
for(j=2;jj++)
{
if(qipan[i-1][j-1]==1)
printf("●");
if(qipan[i-1][j-1]==0)
printf("○");
if(qipan[i-1][j-1]==2)
printf("┴");
}
if(qipan[i-1][j-1]==1)
printf("●");
if(qipan[i-1][j-1]==0)
printf("○");
if(qipan[i-1][j-1]==2)
printf("┘");
printf("\n");
}
}
//判斷輸贏
for(i=0;ii++)
{
for(j=0;jj++)
{
//count=0;
//如果檢測(cè)到該有棋子,則檢查與該棋子有關(guān)的是否可以贏
if(2!=qipan[i][j])
{
colorFlag=qipan[i][j];
countTemp=1;
iTemp=i;
jTemp=j;
//該棋子橫向上是否可以贏
while((++jTemp20)(5!=countTemp))
{
if(colorFlag==qipan[i][jTemp])
{
countTemp++;
if(5==countTemp)
{
if(0==colorFlag)
{
printf("黑棋贏了!\n");
}
elseif(1==colorFlag)
{
printf("白棋贏了!\n");
}
gotowhileEnd;
}
}
else
{
countTemp=0;
break;
}
}
//縱向可以贏
iTemp=i;
jTemp=j;
countTemp=1;
while((++iTemp20)(5!=countTemp))
{
if(colorFlag==qipan[iTemp][j])
{
countTemp++;
if(5==countTemp)
{
if(0==colorFlag)
{
printf("黑棋贏了!\n");
}
elseif(1==colorFlag)
{
printf("白棋贏了!\n");
}
gotowhileEnd;
}
}
else
{
countTemp=0;
break;
}
}
//斜向,從左上到右下方向檢查
iTemp=i;
jTemp=j;
countTemp=1;
while((++iTemp20)(++jTemp20)(5!=countTemp))
{
if(colorFlag==qipan[iTemp][jTemp])
{
countTemp++;
if(5==countTemp)
{
if(0==colorFlag)
{
printf("黑棋贏了!\n");
}
elseif(1==colorFlag)
{
printf("白棋贏了!\n");
}
gotowhileEnd;
}
}
else
{
countTemp=0;
break;
}
}
//斜向,從右上到左下方向檢查
iTemp=i;
jTemp=j;
countTemp=1;
while((++iTemp=0)(--jTemp=0)(5!=countTemp))
{
if(colorFlag==qipan[iTemp][jTemp])
{
countTemp++;
if(5==countTemp)
{
if(0==colorFlag)
{
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 具身認(rèn)知理論在小學(xué)記敘文寫(xiě)作教學(xué)中的應(yīng)用探索
- 數(shù)字時(shí)代隱私保護(hù)決策行為研究:認(rèn)知偏差與理性選擇模型
- 稀有稀土礦資源高效提取與形態(tài)轉(zhuǎn)化研究-洞察闡釋
- 金融科技背景下區(qū)塊鏈技術(shù)的創(chuàng)新與突破
- 購(gòu)物中心商業(yè)空間規(guī)劃技巧
- 健全單位合同管理制度
- 學(xué)前教育本科考研
- 食堂安全培訓(xùn)協(xié)議
- 電商運(yùn)營(yíng)專(zhuān)員勞動(dòng)合同
- 2025至2030年中國(guó)三氯蔗糖行業(yè)市場(chǎng)全景調(diào)查及戰(zhàn)略咨詢研究報(bào)告
- 鐵路工務(wù)檢測(cè)技術(shù)
- 《水利水電工程壓力鋼管制造安裝及驗(yàn)收規(guī)范SLT 432-2024》知識(shí)培訓(xùn)
- DB37-T 5316-2025《外墻外保溫工程質(zhì)量鑒定技術(shù)規(guī)程》
- 2025年中南出版?zhèn)髅郊瘓F(tuán)湖南教育出版社分公司招聘筆試參考題庫(kù)附帶答案詳解
- 2024西部縣域經(jīng)濟(jì)百?gòu)?qiáng)研究
- 《樹(shù)欲靜而風(fēng)不止》課件
- 兒童繪本故事《螞蟻搬家》
- 物聯(lián)網(wǎng)技術(shù)及應(yīng)用基礎(chǔ)(第2版) -電子教案
- 河北省保定市(2024年-2025年小學(xué)六年級(jí)語(yǔ)文)統(tǒng)編版小升初真題(下學(xué)期)試卷及答案
- 水污染控制工程知到智慧樹(shù)章節(jié)測(cè)試課后答案2024年秋黑龍江科技大學(xué)
- 【MOOC】宇宙簡(jiǎn)史-南京大學(xué) 中國(guó)大學(xué)慕課MOOC答案
評(píng)論
0/150
提交評(píng)論