C語(yǔ)言實(shí)現(xiàn)小貓釣魚算法
C語(yǔ)言小貓釣魚實(shí)現(xiàn)了兩個(gè)人打牌,分別依次將牌放到桌子上,若A出的牌與桌子上的牌一樣,則A將桌子上兩張一樣的牌及其中間所有牌放到A手中,看A,B兩個(gè)人誰(shuí)先打完所有牌。
#include <stdio.h> struct queue { int data[1000]; int head; int tail; }; struct stack { int top; int data[10]; }; int main(){ struct queue q1,q2; struct stack s; int i,t,r,flag=0; q1.head=1;q1.tail=1; q2.head=1;q2.tail=1; //初始化桌子 s.top=0; //讀入6個(gè)牌 for(i=1;i<=6;i++) { printf("輸入q1的六張牌:"); scanf("%d",&q1.data[i]); q1.tail++; } for(i=1;i<=6;i++) { printf("輸入q2的六張牌:"); scanf("%d",&q2.data[i]); q2.tail++; } //出牌 while(q1.head<q1.tail&&q2.head<q2.tail) { //debug printf("\nq1手中的牌為:"); for(i=q1.head;i<=q1.tail-1;i++) { printf(" %d",q1.data[i]); } printf("\nq2手中的牌為:"); for(i=q2.head;i<=q2.tail-1;i++) { printf(" %d",q2.data[i]); } if(s.top>0) { printf("\n桌子上的牌是:"); for(i=1;i<=s.top;i++) { printf(" %d",s.data[i]); } printf("\n"); } else { printf("\n桌子上沒(méi)牌了\n"); } //q1出牌 flag=0; t=q1.data[q1.head]; for(i=1;i<=s.top;i++) { if(t==s.data[i]) { flag=1;break; } } if(flag==0) { q1.head++; s.top++; s.data[s.top]=t; } if(flag==1) { q1.head++; q1.data[q1.tail]=t; q1.tail++; while(s.data[s.top]!=t) { q1.data[q1.tail++]=s.data[s.top]; s.top--; } q1.data[q1.tail]=t; q1.tail++; s.top--; } if(q1.head==q1.tail) break; //q2出牌 flag=0; r=q2.data[q2.head]; for(i=1;i<=s.top;i++) { if(r==s.data[i]) { flag=1;break; } } if(flag==0) { q2.head++; s.top++; s.data[s.top]=r; } if(flag==1) { q2.head++; q2.data[q2.tail]=r; q2.tail++; while(s.data[s.top]!=r) { q2.data[q2.tail++]=s.data[s.top]; s.top--; } q2.data[q2.tail]=r; q2.tail++; s.top--; } } if(q1.head==q1.tail) { printf("q2贏了!"); printf("q2手中的牌為:"); for(i=q2.head;i<=q2.tail-1;i++) { printf(" %d",q2.data[i]); } if(s.top>0) { printf("桌子上的牌是:"); for(i=1;i<=s.top;i++) { printf(" %d",s.data[i]); } } else { printf("桌子上沒(méi)牌了"); } } if(q2.head==q2.tail) { printf("q1贏了!"); printf("q1手中的牌為:"); for(i=q1.head;i<=q1.tail-1;i++) { printf(" %d",q1.data[i]); } if(s.top>0) { printf("桌子上的牌是:"); for(i=1;i<=s.top;i++) { printf(" %d",s.data[i]); } } else { printf("桌子上沒(méi)牌了"); } } getchar();getchar(); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
虛函數(shù)表-C++多態(tài)的實(shí)現(xiàn)原理解析
這篇文章主要介紹了虛函數(shù)表-C++多態(tài)的實(shí)現(xiàn)原理,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02C++編程中break語(yǔ)句和continue語(yǔ)句的學(xué)習(xí)教程
這篇文章主要介紹了C++編程中break語(yǔ)句和continue語(yǔ)句的學(xué)習(xí)教程,break和continue是C++循環(huán)控制中的基礎(chǔ)語(yǔ)句,需要的朋友可以參考下2016-01-01MFC對(duì)話框中實(shí)現(xiàn)走馬燈效果
這篇文章主要為大家詳細(xì)介紹了MFC對(duì)話框中實(shí)現(xiàn)走馬燈效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化
本文主要介紹了QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05C語(yǔ)言詳細(xì)分析結(jié)構(gòu)體的內(nèi)存對(duì)齊規(guī)則
C 數(shù)組允許定義可存儲(chǔ)相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲(chǔ)不同類型的數(shù)據(jù)項(xiàng),本篇讓我們來(lái)了解C 的結(jié)構(gòu)體內(nèi)存對(duì)齊2022-07-07