目的:
1.熟悉和更深層掌握循環(huán)結構
2.學習功能設計然后進而通過代碼實現(xiàn)
3.多練習從而熟能生巧
技術:
for語句while語句if語句的高頻使用
死亡編號小游戲代碼如下:
#include "stdafx.h"
#include"iostream"
#define KILLED -1
int _tmain(int argc, _TCHAR* argv[])
{
int total=0;int killNumber=0;int number[10];int count=0;int totalkilledNumber=0;
//提示輸入游戲人數(shù)
printf("請輸入游戲人數(shù):");
scanf("%d",&total);
//給數(shù)組賦值 編號
for(int i=0;i<total;i++)
{
number[i]=i+1;
}
//提示輸入死亡編號
printf("請輸入死亡編號:");
scanf("%",&killNumber);
//開始游戲了
for(int i=0;i<total;i++)
{
//判斷指向的這個人有沒有被殺掉
if(number[i]!=KILLED)
{//報數(shù)
count=count+1;
}
//判斷當前編號是不是到了死亡號碼
if(count==killNumber)
{//殺掉這個人
number[i]=KILLED;
//還原編號
count=0;
//死亡人數(shù)+1
totalkilledNumber++;
//是不是該結束了
if(totalkilledNumber==total-1)
{
break;
}
}
//判斷是否到末尾了
if(i==total-1)
{//讓i回到起始點
i=i-1;
//防止++導致回到第二個
}
printf("\n");
//測試一次之后的結果
for(int i=0;i<total;i++)
{
printf("%d",number[i]);
}
}
system("pause");
return 0;
}
使用宏定義巧妙利用數(shù)組和循環(huán)結構實現(xiàn)對號碼進行篩選魄咕,輸出等功能
猜數(shù)字小游戲代碼如下:
#include "stdafx.h"
#include"iostream"
#include <stdlib.h>
#include <time.h>
int _tmain(int argc, _TCHAR* argv[])
{
//保存原始數(shù)字
int originalArray[4] = {};
//保存猜測的數(shù)字
int guessArray[4] = {};
//記錄數(shù)字和位置都相同的個數(shù)
int countA = 0;
//記錄數(shù)字相同但位置不相同的個數(shù)
int countB = 0;
srand((unsigned int)time(NULL));
for (int i = 0; i < 4; i++) {
bool isExist = false;
int temp = 0;
while(1){
//產生一個隨機數(shù)
temp = rand() % 10;
//判斷是否已經存在
for (int j = 0; j < i; j++) {
if (originalArray[j] == temp) {
//重復了 停止比較 繼續(xù)產生新的
isExist = true;
break;
}
}
//1.重復了 break
//2.比完了 j==i 結束了 沒有重復
if (isExist == false) {
//找到不重復的數(shù)字了
break;
}
}
//插入排序
//尋找這個數(shù)字對應的位置
int j = 0;
for (; j < i; j++){
//j對應的數(shù)字和產生的數(shù)字進行比較
if(temp < originalArray[j]){
//j后面的內容往后移動 騰出空間
for(int k = i; k > j; k--){
originalArray[k] = originalArray[k-1];
}
break;
}
}
//保存到數(shù)組里面去
originalArray[j] = temp;
}
//輸出
// for (int i = 0; i < 4; i++) {
// printf("%d ", originalArray[i]);
// }
// printf("\n");
//1 2 5 6
//1 2 7 8
//開始游戲
while (1) {
printf("請輸入猜測的數(shù)字:");
for (int i = 0; i < 4; i++){
scanf("%d", &guessArray[i]);
}
//判斷用戶的輸入
for (int i = 0; i < 4; i++) {//控制原始數(shù)字
//用原始數(shù)字依次和輸入的4個數(shù)字比較
for (int j = 0; j < 4; j++) {//控制輸入
if (originalArray[i] == guessArray[j]) {
//判斷兩個的位置是否相同
if (i == j) {
//數(shù)字相同 位置也相同
countA++;
} else{
//數(shù)字相同 位置不同
countB++;
}
}
}
}
if (countA == 4) {
//全對
printf("Congratulation!!!");
break;
}else{
printf("%dA%dB\n", countA, countB);
//還原數(shù)據
countA = 0;
countB = 0;
}
}
system("pause");
return 0;
}
先產生隨機數(shù)然后對隨機數(shù)進行判斷,判斷是否重復蚌父,
然后對隨機數(shù)進行排序哮兰,要求小數(shù)在前大數(shù)在后,
最后在終端輸入猜的數(shù)字苟弛,最后編寫提示
感悟:
這兩個小游戲如果在我獨立完成的情況下是不能實現(xiàn)的喝滞,感覺自己對于代碼實現(xiàn)功能這一步很生疏,
雖然大體結構有了膏秫,但是到了具體實現(xiàn)的細節(jié)不能很好的處理好右遭。對于老師寫的代碼,和邏輯思維能
跟的上缤削,但是在某些不熟悉的地方會卡住窘哈。用i,j,k控制循環(huán)次數(shù)和循環(huán)嵌套不熟悉僻他,覺得還是需要多練習宵距。