C语言之猜数字游戏
猜数字游戏
猜数字游戏是以前功能机上的一款益智游戏,计算机会根据输入的位数随机分配一个符合要求的数据,计算机输出guess后便可以输入数字,注意数字间需要用空格或回车符加以区分,计算机会根据输入信息给出相应的提示信息:A表示位置与数字均正确的个数,B表示位置不正确但数字争取的个数,这样便可以根据提示输入,直到正确为止,并且根据输入次数给出相应评价。
源代码如下:
- #include<stdio.h>
- #include<time.h>
- #include<stdlib.h>
- void guess(int);
- int main(void)
- {
- int i,n;
- system("cls"); //清屏
- printf("1.start game?(y/n)\n");
- printf("2.Rule\n");
- printf("3.exit\n");
- printf("please choose:");
- scanf("%d",&i);
- while(i!=3) //循环结构
- {
- switch(i)
- {
- case 1:
- printf("please input n:\n");
- scanf("%d",&n);
- guess(n);
- break;
- case 2:
- printf("\t\tThe rules of the game\n");
- printf("step1:input the number of digits\n");
- printf("step2:input the number,separated by a space between two numbers.\n");
- break;
- default:
- break;
- }
- scanf("%d",&i);
- }
- }
- void guess(int n)
- {
- int acount,bcount,i,j,k=0,flag,a[10],b[10];
- do
- {
- flag=0;
- srand((unsigned long)time(0));
- for(i=0;i<n;i++)
- a[i]=rand()%10;
- for(i=0;i<n-1;i++)
- {
- for(j=i+1;j<=n;j++)
- if(a[i]==a[j]) //不能出现相同的数字
- {
- flag=1;
- break;
- }
- }
- }while(flag==1);
- do
- {
- k++;
- acount=0;
- bcount=0;
- printf("guess:");
- for(i=0;i<n;i++)
- scanf("%d",&b[i]); //输入测试数据
- for(i=0;i<n;i++)
- for(j=0;j<n;j++)
- {
- if(a[i]==b[i]) //位置和数字都相同
- {
- acount++;
- break;
- }
- if(a[i]==b[j]&&i!=j) //数字相同,位置不同
- {
- bcount++;
- break;
- }
- }
- printf("clue on:%dA%d B\n\n",acount,bcount);
- if(acount==n) //给出评价
- {
- if(k==1)
- printf("you are the topmose\n");
- else if(k<=5)
- printf("you are genius!\n");
- else if(k<=10)
- printf("you are cleaver!\n");
- else
- printf("you need try hard!\n");
- break;
- }
- }while(1);
- }
效果图:
C语言之猜数字游戏的更多相关文章
- 李洪强漫谈iOS开发[C语言-049]-猜数字游戏
- [易学易懂系列|rustlang语言|零基础|快速入门|(23)|实战1:猜数字游戏]
[易学易懂系列|rustlang语言|零基础|快速入门|(23)|实战1:猜数字游戏] 项目实战 实战1:猜数字游戏 我们今天来来开始简单的项目实战. 第一个简单项目是猜数字游戏. 简单来说,系统给了 ...
- C语言猜数字游戏
猜数字游戏,各式各样的实现方式,我这边提供一个实现方式,希望可以帮到新手. 老程序猿就不要看了,黑呵呵 源代码1 include stdio.h include stdlib.h include ti ...
- c语言-猜数字游戏
#include <stdio.h> #include <stdlib.h> int top(); int input(); void main() { ; int numbe ...
- java 猜数字游戏
作用:猜数字游戏.随机产生1个数字(1~10),大了.小了或者成功后给出提示. 语言:java 工具:eclipse 作者:潇洒鸿图 时间:2016.11.10 >>>>> ...
- 用MFC完成一个简单的猜数字游戏: 输入的四位数中,位置和数字都正确为A,数字相同而位置不同的为B。
最近学习了MFC一些比较基础的知识,所以打算通过做一个简单的数字游戏来理解MFC的流程并进一步熟悉其操作. 在这里,我做了一个猜数字的小游戏.第一步当然是设计主界面,先给大家展示一下游戏界面: 主界面 ...
- 实验三 Java猜数字游戏开发
课程:Java实验 班级:201352 姓名:程涵 学号:20135210 成绩: 指导教师:娄佳鹏 实验日期:15.06.03 实验密级: ...
- 通过游戏学python 3.6 第一季 第三章 实例项目 猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码 可复制直接使用 娱乐 可封装 函数
猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码 #猜数字--核心代码--猜测次数--随机函数和屏蔽错误代码 import random secrst = random.rand ...
- 通过游戏学python 3.6 第一季 第二章 实例项目 猜数字游戏--核心代码--猜测次数 可复制直接使用 娱乐 可封装 函数
猜数字游戏--核心代码--猜测次数 #猜数字--核心代码--猜测次数 number=33 amount=3 count=0 while count<=amount: conversion ...
随机推荐
- Android开发中如何解决加载大图片时内存溢出的问题
Android开发中如何解决加载大图片时内存溢出的问题 在Android开发过程中,我们经常会遇到加载的图片过大导致内存溢出的问题,其实类似这样的问题已经屡见不鲜了,下面将一些好的解决方案分享给 ...
- HDU 5800 To My Girlfriend(单调DP)
[题目链接]http://acm.hdu.edu.cn/showproblem.php?pid=5800 [题目大意] 给出一个容量上限s,f[i][j][k][l][m]表示k和l两个物品不能选,i ...
- SBT模版
/*Author:WNJXYK*/ #include<cstdio> using namespace std; ; struct SBT{ int left; int right; int ...
- 删除input或textarea输入框在移动版显示的阴影(Safari/iPhone)
移动端浏览网页元素时,自动给input和textarea添加了内部阴影的效果,只需加入样式即可去除 input,textarea{-webkit-appearance: none;} input[ty ...
- MVC5.0 中如何提高Controller 的优先级
//在area下建立的Home namespace WebApplication8.Areas.Weather.Controllers { public class HomeController : ...
- [原创] ASP.NET WEBAPI 接入微信公众平台 总结,Token验证失败解决办法
首先,请允许我说一句:shit! 因为这个问题不难,但是网上有关 ASP.NET WEBAPI的资料太少.都是PHP等等的. 我也是在看了某位大神的博客后有启发,一点点研究出来的. 来看正题! 1.微 ...
- visual studio 2013 使用IIS Express附加调试MVC5
1.如何找到调试的站点的进程[由于图片无法上传,就不上传图片了] 2.vs运行的时候,在状态栏会存在一个IIS Express 进程,点击显示所有的应用程序,找到想要调试的程序的PID; 3.附加调试 ...
- redis在spring中的配置及java代码实现
1.建一个redis.properties属性文件 # Redis Setting redis.addr = 127.0.0.1 redis.port = 6379 redis.auth = mast ...
- (C#)Windows Shell 外壳编程系列8 - 同后缀名不同图标?
原文 (C#)Windows Shell 外壳编程系列8 - 同后缀名不同图标? (本系列文章由柠檬的(lc_mtt)原创,转载请注明出处,谢谢-) 接上一节:(C#)Windows Shell 外壳 ...
- oracle命令大全
内容包括三大项: 1.oracle基本操作语句 2.SQLServer基本操作语句 3.各种数据库连接方法 ******************************************* ...