游戏描述:有6张写有数字1-50的卡片,由用户输入一个1-50的数,用户通过6张卡片来猜数字,最后系统会猜出用户输入的数。
思路分析:1.卡片:定义一个二维数组,得到卡片 2.利用嵌套循环对卡片进行输出:先利用内层循环,循环完同一行,再利用外层循环,换行进行循环 3.最后利用乘方函数对二进制的规律进行判断
二进制规律:例如卡片1的每个数字转化为二进制都是_ _ _ _ _ 1;而卡片2的每个数字转化为二进制都是_ _ _ _1 _。(卡片规律有参考自@五道口纳什)以此类推,看完6张卡片,有该数字的记为1,没有则记为0,则通过6张卡片可以得到6个由0和1组成的六位二进制,通过计算可得出该数。
#include<iostream>
#include<cmath> //用于保存pow函数的头文件
using namespace std;
int main()
{
cout << "请默想一个小于等于50的数字" << endl;
int a, b, c, d, e, f;
int card1[5][5] = {
{
1,3,5,7,9},
{
11,13,15,17,19},
{
21,23,25,27,29},
{
31,33,35,37,39},
{
41,43,45,47,49},
};
for (int i = 0; i < 5; i++) //i表示行数,j表示列数,数组行数和列数从0开始,故i从0开始
for (int j = 0; j < 5; j++) //同一行循环完,再换行进行另一行循环
cout << card1[i][j] << " ";
cout << endl;
cout << "请看第一张卡片上是否有你想的数字,如果有请输入1,没有请输入0"