<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
本章主要講解如何做一個簡易的猜數遊戲,分為使用者猜數和系統猜數。
前置芝士:
系統想好一個在 [ 1 , 100 ] [1,100][1,100] 之間的整數,由使用者來猜數,而系統只能回答“過大”“過小”“正確”。
使用亂數來隨機一個 [ 1 , 100 ] [1,100][1,100] 的整數,猜測數初始設定為 − 1 -1−1。
srand(time(0)); int x=-1,ans=rand()%100+1;
讓系統講清楚每次猜的數位的範圍。
然後就直接讓使用者輸入數位。
printf("I have a number from 1 to 100. Please have a guess: "); scanf("%d",&x);
記一個變數tms,每次加一。
判斷分為四種情況:
1.當x∉[1,100] 時,丟擲錯誤。
if(x<1||x>100) puts("The number is error.");
2.當x>ans 時,說明數位過大,輸出。
else if(x>ans) puts("The number is larger than my number!");
3.當x<ans 時,類似,數位過小,輸出。
else if(x<ans) puts("The number is smaller than my number!");
4.當x=ans 時,正確,提示輸出。
else puts("Oh, you are right!");
外層的迴圈條件,只要x≠ans時,就執行。
while(x!=ans) { ... }
輸出tms 並終止。
printf("You guessed it %d times.",tms);
完整程式碼:
#include<bits/stdc++.h> using namespace std; int main() { srand(time(0)); int x=-1,ans=rand()%100+1,tms=0; while(x!=ans) { printf("I have a number from 1 to 100. Please have a guess: "); scanf("%d",&x); tms++; if(x<1||x>100) puts("The number is error."); else if(x>ans) puts("The number is larger than my number!"); else if(x<ans) puts("The number is smaller than my number!"); else puts("Oh, you are right!"); } printf("You guessed it %d times.",tms); return 0; }
效果:
使用者想好一個[1,100] 範圍的數,讓系統猜。太大輸入L,太小輸入S,正確輸入R。
有了上面的操作,我們讓系統猜,寫起來整體還是很簡單的,但是要讓系統聰明些。
先擺出程式框架:
#include<bits/stdc++.h> using namespace std; int main() { srand(time(0)); puts("Please think a number from 1 to 100. And then I'll guess it."); puts("If I guess right, you should say "R"(Right)."); puts("If my guess is too large, you should say "L"(Large)."); puts("If my guess is too small, you should say "S"(Small)."); puts("DON'T TELL A LIE!n"); char c=' '; int tms=0; while(c!='R') { //... printf("I guess the number is %d.Is it right(R, L or S)? ",/*...*/); scanf("%c%*c",&c); tms++; if(c=='R') break; //... } printf("I guess it %d times!",tms); return 0; }
系統只會瞎猜:
printf("I guess the number is %d.Is it right(R, L or S)? ",rand()%100+1);
效果顯著:
為系統堅持不懈的精神點贊!
顯然,我們可以每一次縮小猜測範圍。
char c=' '; int tms=0,l=1,r=100; while(c!='R') { int t=rand()%(r-l+1)+l; printf("I guess the number is %d. Is it right(R, L or S)? ",t); scanf("%c%*c",&c); tms++; if(c=='R') break; if(c=='L') r=t; if(c=='S') l=t; }
效率提升了:
系統:我是最快的!
Never gonna tell a lie and hurt you~
前面的程式判定不了我們在說謊,因此我們可以就 v2.0 新增一些東西(當l≥r 時必定不合法)。
char c=' '; int tms=0,l=1,r=100; while(c!='R') { int t=rand()%(r-l+1)+l; printf("I guess the number is %d. Is it right(R, L or S)? ",t); scanf("%c%*c",&c); tms++; if(c=='R') break; if(c=='L') r=t; if(c=='S') l=t; if(l>=r) { puts("You told a lie!"); return 0; } }
聰明多了:
沒錯,就是眾望所歸的二分。
改動這個即可:
int t=l+r>>1;
rand():要我有何用?
如果還是猜50,效果:
計算機:驚不驚喜,意不意外!
But——《1 times》!
稍微改改即可,這裡作者就不改了懶得改。
最終程式碼:
#include<bits/stdc++.h> using namespace std; int main() { puts("Please think a number from 1 to 100. And then I'll guess it."); puts("If I guess right, you should say "R"(Right)."); puts("If my guess is too large, you should say "L"(Large)."); puts("If my guess is too small, you should say "S"(Small)."); puts("DON'T TELL A LIE!n"); char c=' '; int tms=0,l=1,r=100; while(c!='R') { int t=l+r>>1; printf("I guess the number is %d. Is it right(R, L or S)? ",t); scanf("%c%*c",&c); tms++; if(c=='R') break; if(c=='L') r=t; if(c=='S') l=t; if(l>=r) { puts("You told a lie!"); return 0; } } printf("I guess it %d times!",tms); return 0; }
到此這篇關於C++小遊戲教學之猜數遊戲的實現的文章就介紹到這了,更多相關C++猜數遊戲內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45