您好,登錄后才能下訂單哦!
使用C語言怎么實現一個小貓釣魚算法?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
C語言是一門面向過程的、抽象化的通用程序設計語言,廣泛應用于底層開發,使用C語言可以以簡易的方式編譯、處理低級存儲器。
C語言小貓釣魚實現了兩個人打牌,分別依次將牌放到桌子上,若A出的牌與桌子上的牌一樣,則A將桌子上兩張一樣的牌及其中間所有牌放到A手中,看A,B兩個人誰先打完所有牌。
#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個牌 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桌子上沒牌了\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("桌子上沒牌了"); } } 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("桌子上沒牌了"); } } getchar();getchar(); }
關于使用C語言怎么實現一個小貓釣魚算法問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。