




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、#include<stdio.h>#define N 10void welcome();void initqipan();void showqi(int i);void save(int p);void panduan(int p);void heqi();void over();int zouqihang();int zouqilie();/*結(jié)構(gòu)體*/struct zuobiao int xN*N; int yN*N;weizhiN*N;/*主函數(shù)*/void main() int p=0; welcome(); initqipan(); for(p=1;p<=N*N;p
2、+) weizhip.xp=zouqihang(); weizhip.yp=zouqilie(); save(p); showqi(p); panduan(p); if(p=N*N) heqi(); over();/*建立棋盤(pán)*/void initqipan() int i,j; for(i=0;i<N;i+) printf("%d",i); printf(" "); printf("n"); for(i=1;i<N;i+) for(j=0;j<N;j+) if(j=0) printf("%d",
3、i); else printf("·"); printf("n"); /*顯示棋子*/void showqi(int p) int i,j,k,m; int aN*N,bN*N; FILE *fp; fp=fopen("wuzi_list","rb"); for(i=1;i<=N*N;i+) fread(&weizhii,sizeof(struct zuobiao),1,fp); ai=weizhii.xi; bi=weizhii.yi; for(m=1;m<p;m+) while(w
4、eizhip.xp=am&&weizhip.yp=bm) printf("error!n"); weizhip.xp=zouqihang(); weizhip.yp=zouqilie(); m=1; for(i=0;i<N;i+) printf("%d",i); printf(" "); printf("n"); for(i=1;i<N;i+) for(j=1;j<N;j+) if(j=1) printf("%d",i); for(k=1;k<=p;k+)
5、 if(i=weizhik.xk&&j=weizhik.yk) if(k%2=1) printf("");break; else if(k%2=0) printf("");break; if(k>p)printf("·"); else continue; printf("n"); /*走棋行*/int zouqihang() int x; printf("請(qǐng)輸入要走棋子所在行數(shù)!n"); printf("x="); scanf("%d
6、",&x); while(x>N-1|x<1) printf("error!n"); printf("請(qǐng)輸入要走棋子所在行數(shù)!n"); printf("x="); scanf("%d",&x); return x;/*走棋列*/int zouqilie() int y; printf("請(qǐng)輸入要走棋子所在列數(shù)!n"); printf("y="); scanf("%d",&y); while(y>N-1|y
7、<1) printf("error!n"); printf("請(qǐng)輸入要走棋子所在列數(shù)!n"); printf("y="); scanf("%d",&y); return y;/*文件保存*/void save(int i) FILE *fp; fp=fopen("wuzi_list","wb"); fwrite(&weizhii,sizeof(struct zuobiao),1,fp);/*判斷輸贏*/void panduan(int p) int i,
8、j,k8=1,1,1,1,1,1,1,1,; int aN*N,bN*N; FILE *fp; fp=fopen("wuzi_list","rb"); for(i=1;i<=p;i+) fread(&weizhii,sizeof(struct zuobiao),1,fp); ai=weizhii.xi; bi=weizhii.yi; /*判斷行*/ for(i=1;i<=p;i+) if(i%2=1) for(j=1;j<=p;j=j+2) if(ai=aj)&&(bi=bj-1) k0+; continue;
9、else if(ai=aj)&&(bi=bj-2) k0+; continue; else if(ai=aj)&&(bi=bj-3) k0+; continue; else if(ai=aj)&&(bi=bj-4) k0+; continue; else if(k0=5) printf("Player 1 wins!n"); else continue; if(k0=5) break; k0=1; else if(k0=5) break; else if(i%2=0) for(j=2;j<=p;j=j+2) if(ai=
10、aj)&&(bi=bj-1) k1+; continue; else if(ai=aj)&&(bi=bj-2) k1+; continue; else if(ai=aj)&&(bi=bj-3) k1+; continue; else if(ai=aj)&&(bi=bj-4) k1+; continue; else if(k1=5) printf("Player 2 wins!n"); else continue; if(k1=5) break; k1=1; /*判斷列*/ for(i=1;i<=p;i+)
11、 if(k0=5|k1=5) break; else if(i%2=1) for(j=1;j<=p;j=j+2) if(ai=aj-1)&&(bi=bj) k2+; continue; else if(ai=aj-2)&&(bi=bj) k2+; continue; else if(ai=aj-3)&&(bi=bj) k2+; continue; else if(ai=aj-4)&&(bi=bj) k2+; continue; else if(k2=5) printf("Player 1 wins!n")
12、; else continue; if(k2=5) break; k2=1; else if(k2=5) break; else if(i%2=0) for(j=2;j<=p;j=j+2) if(ai=aj-1)&&(bi=bj) k3+; continue; else if(ai=aj-2)&&(bi=bj) k3+; continue; else if(ai=aj-3)&&(bi=bj) k3+; continue; else if(ai=aj-4)&&(bi=bj) k3+; continue; else if(k3=
13、5) printf("Player 2 wins!n"); else continue; if(k3=5) break; k3=1; /*判斷對(duì)角(左上-右下)*/ for(i=1;i<=p;i+) if(k0=5|k1=5|k2=5|k3=5) break; else if(i%2=1) for(j=1;j<=p;j=j+2) if(ai=aj-1)&&(bi=bj-1) k4+; continue; else if(ai=aj-2)&&(bi=bj-2) k4+; continue; else if(ai=aj-3)&
14、&(bi=bj-3) k4+; continue; else if(ai=aj-4)&&(bi=bj-4) k4+; continue; else if(k4=5) printf("Player 1 wins!n"); else continue; if(k4=5) break; k4=1; else if(k2=5) break; else if(i%2=0) for(j=2;j<=p;j=j+2) if(ai=aj-1)&&(bi=bj-1) k5+; continue; else if(ai=aj-2)&&
15、(bi=bj-2) k5+; continue; else if(ai=aj-3)&&(bi=bj-3) k5+; continue; else if(ai=aj-4)&&(bi=bj-4) k5+; continue; else if(k5=5) printf("Player 2 wins!n"); else continue; if(k5=5) break; k5=1; /*判斷對(duì)角(左下-右上)*/ for(i=1;i<=p;i+) if(k0=5|k1=5|k2=5|k3=5|k4=5|k5=5) break; else if(
16、i%2=1) for(j=1;j<=p;j=j+2) if(ai=aj+1)&&(bi=bj-1) k6+; continue; else if(ai=aj+2)&&(bi=bj-2) k6+; continue; else if(ai=aj+3)&&(bi=bj-3) k6+; continue; else if(ai=aj+4)&&(bi=bj-4) k6+; continue; else if(k6=5) printf("Player 1 wins!n"); else continue; if(k6
17、=5) break; k6=1; else if(k6=5) break; else if(i%2=0) for(j=2;j<=p;j=j+2) if(ai=aj+1)&&(bi=bj-1) k7+; continue; else if(ai=aj+2)&&(bi=bj-2) k7+; continue; else if(ai=aj+3)&&(bi=bj-3) k7+; continue; else if(ai=aj+4)&&(bi=bj-4) k7+; continue; else if(k7=5) printf("Player 2 wins!n"); else continue; if(k7=5) break; k7=1; /*和棋*/void heqi() printf
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025屆吉林省吉林市長(zhǎng)春汽車經(jīng)濟(jì)開(kāi)發(fā)區(qū)第六中學(xué)高一化學(xué)第二學(xué)期期末聯(lián)考試題含解析
- 北京市首都師大附中2025年化學(xué)高二下期末檢測(cè)試題含解析
- 獸醫(yī)執(zhí)業(yè)注冊(cè)管理辦法
- 材料使用取貨管理辦法
- 出口專用標(biāo)簽管理辦法
- 醫(yī)保藥房售賣管理辦法
- 學(xué)術(shù)質(zhì)量評(píng)估
- 網(wǎng)絡(luò)教學(xué)系統(tǒng)設(shè)計(jì)與實(shí)施方案
- 江蘇徐州地名管理辦法
- 機(jī)型數(shù)量評(píng)審管理辦法
- 社會(huì)救助政策培訓(xùn)
- DB3702-T 0009-2020 市民訴求數(shù)據(jù)分析與應(yīng)用規(guī)范
- 坐大巴車安全教育
- 廣西建設(shè)職業(yè)技術(shù)學(xué)院博士高層次人才招考聘用高頻重點(diǎn)提升(共500題)附帶答案詳解
- 軍事訓(xùn)練傷病預(yù)防
- 阿爾伯特;哈伯德-把信送給加西亞
- 2025中級(jí)消防設(shè)施操作員作業(yè)考試題及答案(1000題)
- 鐵路貨物運(yùn)價(jià)規(guī)則
- 病房突發(fā)事件的應(yīng)急與處理
- 光伏項(xiàng)目運(yùn)維服務(wù)承包合同5篇
- 小學(xué)期末科學(xué)質(zhì)量分析
評(píng)論
0/150
提交評(píng)論