C语言猜数字小游戏智能版

不仅有对错,还有评分系统,根据回答的次数给予合适的反馈。此代码适合linux和安卓系统,如果windows想用得删除\033[xxm之类的ANSI打印转义字符,换成windows对应的清屏、切换颜色函数

#include<stdio.h>
#include <stdlib.h>
#include <time.h>
int count(int x,int y)
//折中法计算最保守猜中的次数
{int amount=y-x+1,i=0;for(; amount>0; i++)amount/=2;return i;
}
int game()
{int guess,randnum,normalCount,x,y,i=0;int sameFlag=0,effectiveCount=0;int preGuess[16]= {0};printf("\033[36m输入两个整数确定范围:\n");scanf("%d%d",&x,&y);while ( getchar() != '\n' );if (x>y)//交换{int tmp=x;x=y;y=tmp;}int clearLowBound=x,clearHighBound=y;//把猜过数后确定的新范围存进这两个数里面randnum=rand()%(y-x+1)+x;printf("请猜一个%d~%d的数:\n",x,y);normalCount=count(x,y);do{i++,sameFlag=0;//i是猜数字的次数,f是有效猜数字的次数scanf("%d",&guess);while (getchar()!= '\n' );if(guess>y||guess<x)printf("超出范围了,请认真输入");else{for(int i=0; i<effectiveCount; i++)//寻找有没有与之前猜过的数相同if (guess==preGuess[i])sameFlag=1;if(sameFlag==1)printf("之前都输入过了,请输入别的");else if(guess<clearLowBound||guess>clearHighBound) //如果猜得超出比先前确定的范围printf("反其道而行🤣 \t");else {effectiveCount++;preGuess[effectiveCount-1]=guess;//如果不是超出界限的情况就把先前输入的数存进数组里面去if(guess<randnum) {clearLowBound=guess;if(i>=normalCount)printf("有点笨啊现在还猜不中😂,猜大点吧 ");elseprintf("猜大一点 ");}else if(guess>randnum) {clearHighBound=guess;if(i>=normalCount)printf("有点笨啊现在还猜不中😂,猜小点吧 ");elseprintf("猜小一点 ");}}}}while (guess!=randnum);if(i<normalCount-1){printf("\033[?25l\033[2J\033[2;1H");//画爱心for (float y = 1.18f; y > -1.5; y -= 0.16f){usleep(30000);for (float x = -1.5f; x < 1.5; x += 0.088f){float a = x * x + y * y - 1;if(a*a*a-x*x*y*y*y<=0)printf("\033[34m*");elseprintf(" ");}printf("\n");}printf("\033[16;1H\033[33m\033[?25h太牛B了回答了%d次就正确了,你是欧皇吗?",i);}else if(i<normalCount)printf("\033[32m恭喜你用了%d次就答对了!",i);else if(i==normalCount)printf("还算正常,用了%d次答对",i);else if(i==normalCount+1&&normalCount>5)printf("\033[35m运气不太好,下次加油吧");elseprintf("\033[31m你这个也是没谁了用了%d次啊,太菜了吧",i);printf("\n你还想继续玩吗?回复1继续\n");int ret;scanf("%d",&ret);printf("\033[2J\033[1;1H");return ret;}
int main()
{srand(time(0));printf("\033[36m按回车键输入,两个数之间用空格隔开\n");while(game()==1);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/688341.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LTE-M与NB-IoT蜂窝物联网

大规模、高速连接的部署需要大量带宽的支持。而蜂窝低功耗广域 (LPWA)技术为传感器和短数据突发交易设备在快速的、以 5G 为中心的技术世界中的不间断运行让路。长期演进机器类型通信 (LTE-M) 和窄带物联网 (NB-IoT)等移动物联网技术提供安全且经济高效的蜂窝 LPWA 功能。它们是…

内存基础知识

内存作用&#xff1a;用来存放数据 int x10&#xff1b; xx1&#xff1b; 这会生成一个可执行文件&#xff08;装入模块&#xff09;然后存入内存地址中 绝对装入&#xff1a;-如果知道程序放到内存中哪个位置&#xff0c;编译程序将产生绝对地址的目标代码 可重定位装入&am…

汽车零部件软件开发中常用滤波算法

滑动窗口滤波器:均值滤波与中值滤波的应用及局限性 滑动窗口滤波是数字信号处理中的基本技术,通过在数据序列上移动一个固定大小的窗口并计算窗口内数据点的统计量(如均值或中值)来平滑信号。本文将探讨滑动窗口均值滤波和中值滤波的基本实现、工作原理及其局限性,并引入…

idea 打不开项目 白屏

使用IDEA打开项目&#xff0c; 不知名原因崩溃了&#xff0c; 直接出现缩略图白屏。 解决过程&#xff1a; 尝试过重启IDEA&#xff0c;重启过电脑&#xff0c;重新引入相同项目&#xff08;使用不同路径&#xff0c;存在缓存记录&#xff0c;依然打不开&#xff09;&#xff…

数据结构——lesson3单链表介绍及实现

目录 1.什么是链表&#xff1f; 2.链表的分类 &#xff08;1&#xff09;无头单向非循环链表&#xff1a; &#xff08;2&#xff09;带头双向循环链表&#xff1a; 3.单链表的实现 &#xff08;1&#xff09;单链表的定义 &#xff08;2&#xff09;动态创建节点 &#…

删除链表的倒数第N个节点

删除链表的倒数第N个节点 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 进阶&#xff1a;你能尝试使用一趟扫描实现吗&#xff1f; 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], n 2 输出&#xff1a;[1,2,3,5] 示例…

蓝桥杯Java组备赛(二)

题目1 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int max Integer.MIN_VALUE;int min Integer.MAX_VALUE;double sum 0;for(int i0;i<n;i) {int x sc.nextInt()…

13.5. 多尺度目标检测

这里是对那一节代码的通俗注释&#xff0c;希望对各位学习有帮助。 值得注意的是&#xff0c;multibox_prior函数的宽高计算网络上有争议&#xff0c;此处我仍认为作者的写法是正确的&#xff0c;如果读者有想法&#xff0c;可以在评论区留言&#xff0c;我们进行讨论。 import…

文件上传漏洞--Upload-labs--Pass03--特殊后缀与::$DATA绕过

方法一&#xff1a;特殊后缀绕过&#xff1a; 一、什么是特殊后缀绕过 源代码中的黑名单禁止一系列后缀名 之外的后缀&#xff0c;称之为‘特殊后缀名’&#xff0c;利用其来绕过黑名单&#xff0c;达到上传含有恶意代码的文件的目的。 二、代码审计 接下来对代码逐条拆解进行…

iocp简单例子

首先说明&#xff1a;纯iocp使用的例子看&#xff1a;纯iocp例子&#xff08;里面的代码可能无法运行&#xff0c;但是下面的代码一定可以运行&#xff0c;可以看看它里面的 PostQueuedCompletionStatus函数的使用&#xff0c;参考参考然后拿出来放到下面的代码里测试&#xff…

VQ23 请按城市对客户进行排序,如果城市为空,则按国家排序(order by和case when的连用)

代码 select * from customers_info order by (case when city is null then country else city end)知识点 order by和case when的连用

VQ30 广告点击的高峰期(order by和limit的连用)

代码 select hour(click_time) as click_hour ,count(hour(click_time)) as click_cnt from user_ad_click_time group by click_hour order by click_cnt desc limit 1知识点 order by和limit的连用&#xff0c;取出所需结果 YEAR() 返回统计的年份 MONTH() 返回统计的月份 D…

解决Ubuntu下网络适配器桥接模式下ping网址不通的情况

问题反应&#xff1a;ping不通网址 打开虚拟机中的设置&#xff0c;更改网络适配器为NAT模式 确定保存更改之后&#xff0c;退出输入如下命令。 命令1&#xff1a; sudo /etc/network/inferfaces 命令2&#xff1a; sudo /etc/init.d/network/ restart

《生产调度优化》专栏导读

文章分类 生产调度优化问题入门相关问题求解调度问题求解效率探讨相关论文解读 生产调度优化问题入门 文章包含重点简述生产车间调度优化问题两种常用的FJSP模型解析FJSP问题的标准测试数据集的Python代码解析FJSP标准测试数据代码 相关问题求解 文章求解器问题类型【作业车…

使用 C++23 从零实现 RISC-V 模拟器(5):CSR

&#x1f449;&#x1f3fb; 文章汇总「从零实现模拟器、操作系统、数据库、编译器…」&#xff1a;https://okaitserrj.feishu.cn/docx/R4tCdkEbsoFGnuxbho4cgW2Yntc RISC-V为每个hart定义了一个独立的控制状态寄存器&#xff08;CSR&#xff09;地址空间&#xff0c;提供了4…

小程序列表下拉刷新和加载更多

配置 在小程序的app.json中&#xff0c;检查window项目中是否已经加入了"enablePullDownRefresh": true&#xff0c;这个用来开启下拉刷新 "window": {"backgroundTextStyle": "light","navigationBarBackgroundColor": &q…

unity C#中的封装、继承和多态简单易懂的经典实例

文章目录 封装 (Encapsulation)继承 (Inheritance)多态 (Polymorphism) C#中的封装、继承和多态是面向对象编程&#xff08;OOP&#xff09;的三大核心特性。下面分别对这三个概念进行深入解释&#xff0c;并通过实例来说明它们在实际开发中的应用。 封装 (Encapsulation) 实例…

【北京航空航天大学】【信息网络安全实验】【实验一、密码学:DES+RSA+MD5编程实验】

信息网络安全实验 实验一、DES RSA MD5 一、实验目的 1. 通过对DES算法的代码编写,了解分组密码算法的设计思想和分组密码算法工作模式; 2. 掌握RSA算法的基本原理以及素数判定中的Rabin-Miller测试原理、Montgomery快速模乘(模幂)算法,了解公钥加密体制的优缺点及其常…

gem5学习(21):索引策略——Indexing Policies

目录 一、集合关联&#xff08;Set Associative&#xff09; 二、倾斜关联&#xff08;Skewed Associative&#xff09; 索引策略确定基于地址将一个块映射到哪个位置。 索引策略的最重要方法是getPossibleEntries()和regenerateAddr()&#xff1a; getPossibleEntries()用…

数组转二叉树的一种方法-java(很特殊)

上代码 Node节点的代码 public class ThreadNode {private int data;private ThreadNode left;private boolean leftTag; // 左子节点是否为线索private ThreadNode right;private boolean rightTag; // 右子节点是否为线索// ... 省略get和set方法// ... 省略构造方法// ... …