复杂的C语言彩票系统代码

时间: 2023-12-22 11:04:58 浏览: 45
以下是一个复杂的C语言彩票系统代码,包含了更多功能和细节处理,仅供参考: ```c #include <stdio.h> #include <stdlib.h> #include <time.h> #define MAX_NUM 33 // 彩票号码最大值 #define MIN_NUM 1 // 彩票号码最小值 #define NUM_COUNT 6 // 彩票号码个数 // 彩票号码结构体 typedef struct { int nums[NUM_COUNT]; // 号码数组 } Lottery; // 用户猜测结构体 typedef struct { int nums[NUM_COUNT]; // 号码数组 } Guess; // 中奖信息结构体 typedef struct { int prize; // 奖项,0表示未中奖,1~3表示三等奖到一等奖 int prizeNums[NUM_COUNT]; // 中奖号码 } Result; // 生成n个不重复的随机数 void generateRandomNums(int nums[], int n, int max, int min) { int i, j, temp; srand(time(NULL)); for (i = 0; i < n; i++) { nums[i] = rand() % (max - min + 1) + min; for (j = 0; j < i; j++) { if (nums[i] == nums[j]) { i--; break; } } } } // 输入n个不重复的整数 void inputUniqueNums(int nums[], int n, int max, int min) { int i, j; for (i = 0; i < n; i++) { printf("第%d个号码:", i + 1); scanf("%d", &nums[i]); // 判断号码是否合法 if (nums[i] < min || nums[i] > max) { printf("号码必须在%d~%d之间!\n", min, max); i--; continue; } // 判断号码是否重复 for (j = 0; j < i; j++) { if (nums[i] == nums[j]) { printf("号码不能重复!\n"); i--; break; } } } } // 比较两个号码数组,返回匹配的号码个数 int compareNums(int nums1[], int nums2[], int n) { int i, j, count = 0; for (i = 0; i < n; i++) { for (j = 0; j < n; j++) { if (nums1[i] == nums2[j]) { count++; break; } } } return count; } // 比较猜测的号码和彩票号码,返回中奖信息 Result checkGuess(Lottery lottery, Guess guess) { Result result; int match = compareNums(lottery.nums, guess.nums, NUM_COUNT); if (match == 6) { result.prize = 1; } else if (match == 5) { result.prize = 2; } else if (match == 4) { result.prize = 3; } else { result.prize = 0; } if (result.prize > 0) { int i, j, count = 0; for (i = 0; i < NUM_COUNT; i++) { for (j = 0; j < NUM_COUNT; j++) { if (guess.nums[i] == lottery.nums[j]) { result.prizeNums[count] = guess.nums[i]; count++; break; } } } } return result; } // 输出彩票号码 void printLottery(Lottery lottery) { int i; printf("彩票号码:"); for (i = 0; i < NUM_COUNT; i++) { printf("%d ", lottery.nums[i]); } printf("\n"); } // 输出用户猜测 void printGuess(Guess guess) { int i; printf("您的猜测:"); for (i = 0; i < NUM_COUNT; i++) { printf("%d ", guess.nums[i]); } printf("\n"); } // 输出中奖信息 void printResult(Result result) { if (result.prize == 0) { printf("很遗憾,您没有中奖。\n"); } else { printf("恭喜您中了%d等奖!\n", result.prize); printf("中奖号码:"); int i; for (i = 0; i < NUM_COUNT; i++) { printf("%d ", result.prizeNums[i]); } printf("\n"); } } int main() { Lottery lottery; Guess guess; Result result; int mode; printf("欢迎来到彩票系统!\n"); printf("请选择模式:\n"); printf("1. 生成彩票号码\n"); printf("2. 输入彩票号码\n"); printf("请选择模式(1或2):"); scanf("%d", &mode); if (mode == 1) { generateRandomNums(lottery.nums, NUM_COUNT, MAX_NUM, MIN_NUM); printf("彩票号码已生成!\n"); } else if (mode == 2) { printf("请按要求输入彩票号码:\n"); inputUniqueNums(lottery.nums, NUM_COUNT, MAX_NUM, MIN_NUM); } else { printf("无效的选择!\n"); return 0; } printLottery(lottery); printf("请猜测%d个%d~%d之间的整数(不重复):\n", NUM_COUNT, MIN_NUM, MAX_NUM); inputUniqueNums(guess.nums, NUM_COUNT, MAX_NUM, MIN_NUM); printGuess(guess); result = checkGuess(lottery, guess); printResult(result); return 0; } ``` 该代码通过定义结构体来存储彩票号码和用户猜测的号码,并通过函数来实现随机数生成、输入不重复整数、比较号码数组等功能。还实现了两种模式的彩票号码生成,以及输出中奖信息和中奖号码。同时,对输入的号码进行了合法性和重复性的判断,使程序更加健壮。

相关推荐

最新推荐

recommend-type

餐馆点菜系统C语言源代码

主要为大家详细介绍了餐馆点菜系统C语言源代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

彩票购买系统-C语言源代码

彩票购买系统-C语言源代码,适合初级C语言学习的朋友参考练习,对编写小程序有一定帮助,希望能对C语言爱好者有所帮助。
recommend-type

基于C语言实现点餐系统

主要为大家详细介绍了基于C语言实现点餐系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现电话簿管理系统

主要为大家详细介绍了C语言实现电话簿管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现简单航班管理系统

主要为大家详细介绍了C语言实现简单航班管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SQL怎么实现 数据透视表

SQL可以通过使用聚合函数和GROUP BY子句来实现数据透视表。 例如,假设有一个销售记录表,其中包含产品名称、销售日期、销售数量和销售额等信息。要创建一个按照产品名称、销售日期和销售额进行汇总的数据透视表,可以使用以下SQL语句: ``` SELECT ProductName, SaleDate, SUM(SaleQuantity) AS TotalQuantity, SUM(SaleAmount) AS TotalAmount FROM Sales GROUP BY ProductName, SaleDate; ``` 该语句将Sales表按照ProductName和SaleDat
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。