C++——基础复习——双色球

跟着哔站的视频复习一遍基础知识,根据老师的思路写双色球项目。相较老师的程序加入了一些功能。没有用到模板知识,欢迎交流。

1、6个红球1个蓝球,红球号码1-33,号码不重复;篮球号码1-15.

2、自选号码功能:要甄别号码是否重复,用了一个数组标记号码是否已出现;越界或者重复情况,清空缓冲区内容,重新输入。掌握了cin.fail()、cin.clear()、cin.ignore(numeric_limits<streamsize>::max(),'\n')几个知识点。每次和用户交互后都要注意缓冲区遗留内容会影响后续输入的可能性。

3、机选号码功能:同样要甄别号码是否重复,使用数组存放号码源,获得随机下标后,取号码,将剩余的号码复制到新数组中,更新号码源。

4、加入了延时开奖功能和倒计时功能:引入了thread中this_thread命名空间下sleep_for()休眠函数;chrono头文件对于时间处理更加便捷。chrono::seconds(1)表示1秒。

5、打印函数中,利用sstream头文件中的ostringstream类创建字符串流,将数组中的内容加入字符串并利用iomanip头文件来控制输出格式,最后获取ostringstream::str()字符串。

上代码:

#include<iostream>
using namespace std;
#include"PlayGame.h"
#include<ctime>
#include<random>
int main() {srand((unsigned int)time(NULL));playgame();return 0;
}
#pragma once
#define COUNTBALL 7
#define REDBALLRANGE 33
#define BLUEBALLRANGE 15void playgame();											//主程序函数
int GetNumber();											//读取数字的工具函数
int* GetOptionalNum();										//自选号码函数
int* GetRandomNum();										//机选号码函数
void printNumBall(int* numball,int len);					//打印函数
int* GetWinNum();											//获得中奖号码
void Mysort(int* numball, int len);							//排序函数
void BonusCaculation(int* numball, int len,int* WinNum);	//开奖函数
#include "PlayGame.h"
#include<iostream>
using namespace std;
#include<sstream>
#include<iomanip>
#include<thread>
#include<chrono>
void playgame()
{int ExitFlag = 0;while (!ExitFlag) {cout << "*********************" << endl;cout << "1.自选号码" << endl;cout << "2.机选号码" << endl;cout << "0.退出系统" << endl;cout << "*********************" << endl;int choice = GetNumber();int* numball = NULL;switch (choice) {case 0:ExitFlag = 1;break;case 1:numball = GetOptionalNum();break;case 2:numball = GetRandomNum();break;default:break;}if (numball) {cout << "你选的号码是:\t";printNumBall(numball, COUNTBALL);cout << "距离开奖还有5秒" << endl;int sec = 5;while (sec) {cout << sec << endl;this_thread::sleep_for(chrono::seconds(1));sec--;}cout << "中奖号码是:\t";int *WinNum = GetWinNum();printNumBall(WinNum, COUNTBALL);BonusCaculation(numball, COUNTBALL, WinNum);}system("pause");system("cls");}
}
//数字读取函数
int GetNumber()
{int res = -1;cin >> res;while (cin.fail()) {cin.clear();cin.ignore(1);cin >> res;}return res;
}
//用户输入自选号,
int * GetOptionalNum()
{int* numball = new int[COUNTBALL];									//申请双色球数组,存放用户自选号cout << "请输入六个红球数字(1~33):" << endl;						int numflag[REDBALLRANGE+1] = { 0 };											//标记是否重复1表示已出现,0表示未出现for (int i = 0; i < COUNTBALL-1; i++) {								//循环读取好吗,前6个是红球numball[i] = GetNumber();//判断号码是否出界和重复if ((numball[i] >= 1 && numball[i] <= REDBALLRANGE && numflag[numball[i]] == 1) || numball[i] < 1 || numball[i]>REDBALLRANGE) {cout << "红球输入不合法,请重新输入:" << endl;cin.ignore(numeric_limits<streamsize>::max(),'\n');			//如果重复忽略掉后面所有输入,直至回车i = -1;														//重置读取循环,重新读取for (int& elem : numflag) {									//重置重复标志elem = 0;}}else if (numball[i] >= 1 && numball[i] <= REDBALLRANGE) {		//不重复、不越界,正常读取存放numflag[numball[i]] = 1;									//已存放的号码球重复标志设置为1}}cin.ignore(numeric_limits<streamsize>::max(), '\n');				//忽略掉缓冲区多余内容,避免影响后续输入cout << "请输入蓝球数字(1~15):";numball[6] = GetNumber();											//读取蓝球号码while (!(numball[6] >= 1 && numball[6] <= BLUEBALLRANGE)) {cout << "蓝球输入不合法,请重新输入:";numball[6] = GetNumber();}cin.ignore(numeric_limits<streamsize>::max(), '\n');Mysort(numball, COUNTBALL - 1);										//红球排序return numball;
}
//获得一组机选号
int * GetRandomNum()
{int* numball = new int[COUNTBALL];									//申请双色球数组,存放机选号int* numsource = new int[REDBALLRANGE];								//申请一个数组,存放号码源,机选号从号码源读取for (int i = 0; i < REDBALLRANGE; i++) {							//初始化号码源 1-33numsource[i] = i + 1;}for (int i = 0; i < COUNTBALL - 1; i++) {							//生成6个红球随机号码int index = rand() % (REDBALLRANGE - i);						//生成号码源的随机下标numball[i] = numsource[index];									//从号码源读取随机下标位置的号码int *temp = new int[REDBALLRANGE - i - 1];						//申请一个新数组,比号码源少一个元素for (int j = 0,k = 0; j < REDBALLRANGE - i - 1; j++,k++) {		//将号码源复制到新数组					if (k != index) {											temp[j] = numsource[k];}else {														//当复制到已读取过的元素跳过temp[j] = numsource[++k];}}delete numsource;numsource = temp;}numball[6] = rand() % BLUEBALLRANGE + 1;Mysort(numball, COUNTBALL - 1);										//红球排序return numball;
}
//打印双色球
void printNumBall(int * numball, int len)
{ostringstream oss;for (int i = 0; i < len; i++) {oss << setw(2) << setfill('0') << numball[i] << "  ";}string str = oss.str();cout << str << endl;
}int * GetWinNum()
{return GetRandomNum();
}
//从小到大排序
void Mysort(int * numball, int len)
{//选择排序//for (int i = 0; i < len - 1; i++) {//	int minindex = i;//	int j = 0;//	for (j = i + 1; j < len; j++) {//		if (numball[j] < numball[i]) {//			minindex = j;//		}//	}//	if (minindex != i) {//		int temp = numball[i];//		numball[i] = numball[minindex];//		numball[minindex] = temp;//	}//}//冒泡排序for (int i = 0; i < len ; i++) {for (int j = 0; j < len - 1 - i; j++) {if (numball[j] > numball[j + 1]) {int temp = numball[j];numball[j] = numball[j + 1];numball[j + 1] = temp;}}}
}
//+--------------------------------------------+
//|-------一等奖:6+1-----------500000元-------|
//|-------二等奖:6或者5+1------200000元-------|
//|-------三等奖:5或者4+1------50000 元-------|
//|-------四等奖:4或者3+1------5000  元-------|
//|-------五等奖:3或者2+1------500   元-------|
//|-------六等奖:2或者1+1------50    元-------|
//|-------七等奖:1或者1--------5     元-------|
//|--------------------------------------------|
//
void BonusCaculation(int * numball, int len, int* WinNum)
{int cnt = 0, blue = 0, res = 0;for (int i = 0; i < len - 1; i++) {if (numball[i] == WinNum[i]) {cnt++;}}if (numball[len - 1] == WinNum[len - 1]) {blue = 1;}int awards[7] = { 500000,200000,50000,5000,500,50,5 };res = cnt + blue;if (res) {cout << "恭喜你,中" << 8 - res << "等奖,奖金" << awards[7 - res] << "元" << endl;}else {cout << "很遗憾,你没有中奖" << endl;}
}

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

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

相关文章

Seata 入门知识

目录 概述 工作流程 工作模式 AT模式 TCC模式 概述 Seata 是一款开源的分布式事务解决方案&#xff0c;致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式&#xff0c;为用户打造一站式的分布式解决方案。 AT模式是阿里首推…

CUDA C++ 编程指南

目录 1. Introduction1.1. The Benefits of Using GPUs1.2. CUDA: A General-Purpose Parallel Computing1.3. A Scalable Programming Model CUDA C Programming Guide 1. Introduction 1.1. The Benefits of Using GPUs 在相似的价格和功耗范围内&#xff0c;图形处理单…

9个最受欢迎的开源自动化测试框架盘点!

自动化测试框架可以帮助测试人员评估多个Web和移动应用程序的功能&#xff0c;安全性&#xff0c;可用性和可访问性。尽管团队可以自己构建复杂的自动化测试框架&#xff0c;但是当他们可以使用现有的开源工具&#xff0c;库和测试框架获得相同甚至更好的结果时&#xff0c;通常…

Github开源贡献者的狂欢——教你如何免费领取价值$200的Starknet空投

前言&#xff1a; 2024 又迎来了四年一度的 BTC 减半时刻&#xff0c;币圈仿佛一下又热闹了起来&#xff0c;这几天有一个新的基于 ETH 的项目诞生了&#xff1a;StarkNet&#xff0c;代号 STRK&#xff0c;凡是在前 5000 个开源项目贡献过至少 3 个 commit 的程序猿都会被空投…

dhtml图片白色区域透明

2011-3-15 关于透明色别人已经讲的很好了&#xff0c;这里记录了一个测试例子。 gif只支持索引色透明&#xff0c;比如规定#FFFFFF为透明&#xff0c;那么图片中所有白色区域都完全透明。 而png支持alpha透明&#xff0c;任何颜色都可以透明&#xff0c;而且有透明度这样一个…

Linux系统网络服务部分拓展练习

1&#xff09;网关服务器&#xff1a;ens36&#xff1a;12.0.0.254/24&#xff0c;ens33&#xff1a;192.168.241.254/24&#xff1b;Server1&#xff1a;192.168.241.0/24&#xff1b;PC1和server2&#xff1a;自动获取IP&#xff1b;交换机无需配置。要求能够使用Xshell等远程…

MySQL - 事务日志

目录 1. redo日志 1.1 为什么需要REDO日志 1.2 REDO日志的好处、特点 1. 好处 2. 特点 1.3 redo的组成 1.4 redo的整体流程 1.5 redo log的刷盘策略 1.6 不同刷盘策略演示 1. 流程图 ​编辑2. 举例 1.7 写入redo log buffer 过程 1.8 redo log file 1. 相关参数…

matlab倒立摆小车LQR控制动画

1、内容简介 略 54-可以交流、咨询、答疑 2、内容说明 略 摆杆长度为 L&#xff0c;质量为 m 的单级倒立摆(摆杆的质心在杆的中心处)&#xff0c;小车的质量为 M。在水平方向施加控制力 u&#xff0c;相对参考系产生位移为 y。为了简化问题并且保其实质不变&#xff0c;忽…

【SelectIO】bitslice原语学习记录

基本概念 在Ultrascale (plus)系列上的FPGA中&#xff0c;Xilinx引入了bitslice硬核&#xff0c;它取代了7系列上的IDELAYCTRL/IODELAY/IOSERDES/IODDR系列硬核&#xff0c;用于为HP&#xff08;High Performance&#xff09;类型Bank上的IO接口提供串并转化、信号延时、三态控…

【k8s资源调度-HPA(自动扩缩容)】

1、HPA可以做什么&#xff1f; 通过观察pod的cpu、内存使用率或自定义metrics指标进行自动的扩容或缩容pod的数量。通常用于Deployment&#xff0c;不适用于无法扩/缩容的对象&#xff0c;如DaemonSet。控制管理器每隔30s(可以通过-horizontal-pod-autoscaler–sync-period修改…

特征选择|一种提升预测模型性能的方法(原理及其优化实现,Matlab)

文章来源于我的个人公众号&#xff1a;KAU的云实验台&#xff0c;主要更新智能优化算法的原理、应用、改进 如今&#xff0c;生成的数据集呈指数级增长&#xff0c;这将产生具有大量特征和样本的数据集&#xff0c;而显然&#xff0c;某些特征是不相关/冗余的&#xff0c;它们…

springBoot整合Redis(一、Jedis操作Redis)

在springboot环境下连接redis的方法有很多&#xff0c;首先最简单的就是直接通过jedis类来连接&#xff0c;jedis类就相当于是redis的客户端表示。 但是因为现在比较常用的是&#xff1a;StringRedisTemplate和RedisTemplate&#xff0c;所以jedis只做简单的介绍。 一、Jedis…

powershell中安装git

以管理员权限打开 PowerShell。 在 PowerShell 中&#xff0c;你可以使用 winget 这个 Windows 的包管理器来安装 Git。下列命令会安装 Git&#xff1a; winget install --id Git.Git -e --source winget另一种方式是直接从 Git 官方网站下载安装程序&#xff0c;并运行它完…

Langchain-Chatchat部署总结

项目地址&#xff1a; https://github.com/chatchat-space/Langchain-Chatchat 整体安装比较方便&#xff0c;在阿里云购买云主机&#xff0c;购买的国外站点机器&#xff0c; 该项目运行最佳坏境为 Linux Ubuntu 22.04.5Python 版本 3.11.7CUDA 版本: 12.1torch2.1.2 使…

Spring的优点

1.方便解耦&#xff0c;简化开发 Spring就是一个容器&#xff0c;可以将所有对象创建和关系维护交给Spring管理。 2.AOP编程支持 面向切面编程&#xff0c;方便实现程序进行权限拦截&#xff0c;运行监控等功能。 3.声明式事务的支持 通过配置完成事务的管理&#xff0c;…

Vue全局事件防止重复点击(等待请求)【进阶版】

继《Vue全局指令防止重复点击&#xff08;等待请求&#xff09;》之后&#xff0c;感觉指令方式还是不太友好&#xff0c;而且嵌套闭包比较麻烦&#xff0c;于是想到了Vue的全局混入&#xff0c;利用混入&#xff0c;给组件绑定click事件。 一、实现原理 与指令方式大致一样&…

针对小型企业网络防护的免费防火墙软件

针对小型企业网络防护&#xff0c;以下是一些适合的防火墙软件/解决方案&#xff1a; pfSense&#xff1a;pfSense 是一款基于 FreeBSD 的开源防火墙和路由器软件&#xff0c;提供丰富的功能和灵活的配置选项&#xff0c;适合用于小型企业网络防护。它支持多种功能&#xff0c;…

代码随想录算法训练营第五十五天| 309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费

309.最佳买卖股票时机含冷冻期 题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 解题思路&#xff1a;今天若买入&#xff0c;应当是前天积攒的利润减去当前股票 java&#xff1a; class Solution {public int maxProfit(int[] prices) {if (prices null |…

Linux 网络命令指南

目录 配置IP地址和子网掩码 网络接口的详细信息 测试与目标主机的连通性 下载文件或内容 远程登录&#xff0c;进行远程管理和协作 CentOS / Red Hat&#xff08;使用 firewalld&#xff09; 关闭防火墙 开启防火墙 配置TCP端口&#xff08;假设使用3306端口&#xff…

最短路径算法总结(Dijkstra、Bellman-ford、SPFA和Floyd)

在最短路径算法中&#xff0c;常用的有Dijkstra、Bellman-ford、spfa、Floyd这四大算法 Dijkstra&#xff1a;迪克斯特拉算法Bellman-ford&#xff1a;贝尔曼-福特算法SPFA&#xff1a;Shortest Path Faster Algorithm算法Floyd&#xff1a;弗洛伊德算法 四大算法介绍 简介 …