c语言编程-编写围棋系统

2023-12-25 14:30

本文主要是介绍c语言编程-编写围棋系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C语言编写围棋系统,不用全局数组和链表 系统功能要求 以菜单的方式完成以下功能,

1.菜单形式如下。 【注意】以下示例均只供参考。

(1)从本地文件导入棋手信息 读取按一定格式存储在本地文件中的信息;本地文件格式可为文本文件或者二进制文件,可自行决定。可参考以下存储格式。

(其中,2表示文件中存储棋手的总人数)

2

P001 连笑 职业 九段 8899

P002 柯洁 职业 九段 9442

(2)保存棋手信息至本地文件 将棋手信息保存至本地文件,并提示保存是否成功。可以存储为文本文件或者二进制文件,请你自己决定。
(3)显示棋手信息 显示所有棋手信息,并注意将各项数据对齐,若无信息,则给出相关提示。
(4)查询棋手信息 提示用户可分别按照棋手身份、棋手姓名、棋手段位进行信息查询,并根据用户提供的选择进行查询结果显示。可以根据自身情况决定是否实现模糊查询功能。

A. 按棋手身份查询

B. 按棋手姓名查询

C. 按棋手段位查询

D. 退出当前功能 请选择(A-D): C

请输入棋手段位: 九段

查询结果如下:

共2人

棋手编号 棋手姓名 棋手身份 棋手段位 等级分

P001 连笑 职业 九段 8899



P002 柯洁 职业 九段 9442

【注意】以下对棋手信息的增、删、改操作都要:

保存到对应的数据文件。

要有操作确认的提示和操作成功的提示。

操作成功后,显示所有棋手信息。

(5)增加棋手信息 提示用户按一定格式输入要增加的一名棋手信息,并提示是否添加成功。
(6)删除棋手信息 提示用户输入棋手编号、姓名,根据输入确定要删除的棋手信息,若没有该棋手信息,则提示查无此人;若有,提示用户是否删除该数据,用户确认删除则删除棋手信息。最后提示相应系统信息。

输入棋手编号、姓名: P004 陈真

完整信息: P004 陈真 业余 2段 80

是否删除该数据y/n?:y

删除成功!

本地文件更新成功!

(7)修改棋手信息 提示用户输入棋手编号、姓名,根据输入确定要修改的修改信息。若没有该棋手信息,则提示查无此人;若有,则先输出该棋手的全部信息,之后询问用户修改哪项信息。用户选择修改项后,提示用户是否要修改。用户若确认修改则修改棋手信息,若放弃修改则退出当前功能。最后提示相应系统信息。

【注意:棋手编号不能更改!】

输入棋手编号、姓名: P001 连笑

完整信息:P001 连笑 职业 九段 8899

选择要修改数据项(1-4):4

是否修改该数据y/n?: y

输入修改信息:8900 修改成功!

本地文件更新成功!

(8)统计棋手信息 提示用户可按照三种方式进行统计:统计某身份某段位棋手总数、统计职业二段以上的棋手总数、统计业余棋手总数。根据输入,输出相应棋手数量和棋手信息。

A. 统计某身份某段位棋手总数

B. 统计职业二段以上的棋手总数

C. 统计业余棋手总数

D. 退出当前功能 请选择(A-D): A

输入棋手身份和段位:职业 九段

当前棋手数量:2

棋手编号 棋手姓名 棋手身份 棋手段位 等级分

P001 连笑 职业 九段 8900

P002 柯洁 职业 九段 9422

(9)对棋手信息进行排序 提示用户可按照两种方式进行排序:对所有棋手按等级分进行降序排序、对职业棋手按段位进行降序排序(等级分或段位相同的棋手按照棋手编号后三位数字大小升序排列)。根据输入信息进行排序,输出排序后的棋手信息。

A. 所有棋手按等级分进行降序排序

B. 职业棋手按段位进行降序排序

C. 退出当前功能 请选择(A-C): B

排序结果:

棋手编号 棋手姓名 棋手身份 棋手段位 等级分

P001 连笑 职业 九段 8900

P002 柯洁 职业 九段 9422

(10)提示用户是否退出该系统,确认后退出系统。
2. 程序设计要求

(1)要合理使用数据结构,包括数组、枚举、结构体等。

(2)逻辑独立的功能定义在函数中,并利用指针进行参数传递。

(3)要有合理提示,例如修改、删除需提示确认。

(4)考虑程序鲁棒性,对不合法数据要有错误处理机制。

(5)所有数据保存在文件中。

        要实现一个围棋棋手管理系统,需要定义一个棋手信息的结构体,然后根据功能需求实现各种操作。下面是一个C语言实现方案。这个方案基于文本文件作为数据存储,涵盖了基本的数据读取、保存、显示、查询、增加、删除、修改、统计和排序功能。

定义棋手信息结构体:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define MAX_PLAYERS 100typedef struct {char id[10];char name[50];char type[10]; // 职业或业余char rank[10]; // 段位int score;     // 等级分
} Player;

主菜单函数和各功能函数原型:

void importPlayers(Player players[], int *count);
void savePlayers(const Player players[], int count);
void showPlayers(const Player players[], int count);
void addPlayer(Player players[], int *count);
void deletePlayer(Player players[], int *count);
void modifyPlayer(Player players[], int count);
void searchPlayers(const Player players[], int count);
void sortPlayers(Player players[], int count);
void statsPlayers(const Player players[], int count);
int menu();int main() {Player players[MAX_PLAYERS];int count = 0;int choice;char exitConfirm;while (1) {choice = menu();switch (choice) {case 1:importPlayers(players, &count);break;case 2:savePlayers(players, count);break;case 3:showPlayers(players, count);break;case 4:addPlayer(players, &count);break;case 5:deletePlayer(players, &count);break;case 6:modifyPlayer(players, count);break;case 7:searchPlayers(players, count);break;case 8:sortPlayers(players, count);break;case 9:statsPlayers(players, count);break;case 10:printf("您确定要退出系统吗?(y/n): ");scanf(" %c", &exitConfirm); // 读取用户输入,注意前面的空格字符if (exitConfirm == 'y' || exitConfirm == 'Y') {printf("感谢使用,再见!\n");return 0; // 退出程序}break; // 如果用户选择不退出,继续显示菜单default:printf("无效选项,请重新选择。\n");}}return 0; // 程序正常退出
}

基本功能实现:

从本地文件导入棋手信息: 读取文件,解析数据,填充到Player数组。
保存棋手信息至本地文件: 遍历Player数组,将数据格式化写入文件。
显示棋手信息: 遍历Player数组,打印每个棋手的信息。
查询棋手信息: 提供多种查询方式,根据输入的条件在Player数组中查找匹配项并显示。
增加棋手信息: 读取用户输入的棋手信息,添加到Player数组。
删除棋手信息: 根据用户输入的条件,在Player数组中查找并删除匹配的棋手。
修改棋手信息: 根据用户输入,找到特定的棋手并允许用户修改信息。
统计棋手信息: 根据用户选择的统计方式,对Player数组中的数据进行统计。
对棋手信息进行排序: 根据用户选择的排序方式,对Player数组中的数据进行排序。

 数据文件格式: 文本文件格式可以如下所示,每行代表一个棋手的信息,项目之间用空格分隔:

P001 连笑 职业 九段 8899
P002 柯洁 职业 九段 9442

错误处理和用户提示: 每个功能中都应包含对错误输入的处理和对用户的适当提示。

程序的鲁棒性: 在处理用户输入和文件操作时要检查可能的错误,如文件不存在、输入格式不正确等。

 运行结果:

1.从本地文件导入棋手信息 

2.见4 

3.显示棋手信息 

 

4.增加棋手信息 和保存信息至本地文件

 

5.删除棋手信息 

6.修改棋手信息 

7.查询棋手信息 

8.对棋手信息进行排序 

9.统计棋手信息 

10.退出系统 

 

这篇关于c语言编程-编写围棋系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/535839

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验