news 2026/2/28 1:38:03

c语言实验4

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
c语言实验4

物联1251 赵海静
题目1:数据持久化——增加与保存
【任务】:编写程序,从控制台输⼊ 5 个廉江红橙产地的信息,将其存⼊结构体数组中,并使⽤ fprintf 函数将数组内容持久化存储到名为 farms.txt 的⽂本⽂件中。
⽂件操作重点:使⽤ “w” 模式打开⽂件,掌握 fprintf 的格式化写⼊。
要求:每⾏存储⼀个产地的信息,字段间⽤空格分隔。

#include<stdio.h>#include<string.h>#include<stdlib.h>typedefstruct{intid;charname[50];intyield;}OrangeFarm;intmain(){OrangeFarm farms[100];intcount=0;intdeleted;charconfirm;FILE*fp;fp=fopen("farms.txt","r");if(fp==NULL){printf("错误:无法打开farms.txt,请确保文件已存在。\n");return1;}while(fscanf(fp,"%d %s %d",&farms[count].id,farms[count].name,&farms[count].yield)==3){count++;}fclose(fp);if(count==0){printf("数据库为空,无数据可删除。\n");return0;}printf("\n---当前廉江红橙产地列表---\n");for(inti=0;i<count;i++){printf("[%d] % -12s",farms[i].id,farms[i].name);if((i+1)%3==0){printf("\n");}}printf("\n------------------\n");printf("请输入要删除的产地 ID:");scanf("%d",&deleteld);inttargetlndex=-1;for(inti=0;i<count;i++){if(farms[i].id==deleteld){targetlndex=1;break;}}if(targetlndex==-1){printf("错误:未找到ID为 %d 的记录。\n",deleteld);return0;}printf("\n拟删除记录详情:\n");printf("ID: %d | 名称: %s | 产量: %d 吨\n",farms[targetlndex].id,farms[targetlndex].name,farms[targetlndex].yield);printf("警告:此操作不可撤回!确定删除吗?(y/n):");getchar();scanf("%c",&confirm);if(confirm!='y'&&confirm!='Y'){printf("操作已安全取消。\n");return0;}for(inti=targetlndex;i<count-1;i++){farms[i]=farms[i+1];}count--;fp=fopen("farms.txt","w");if(fp==NULL){printf("系统错误:无法更新文件数据。\n");return1;}for(inti=0;i<count;i++){fprintf(fp,"%d %s %d\n",farms[i].id,farms[i].name,farms[i].yield);}fclose(fp);printf("成功:ID为 %d 的记录已从系统中能够彻底移除。\n",deleteld);return0;}

题目2:数据过滤——读取与删除
【任务】:先将 farms.txt 中的所有数据加载到结构体数组中。⽤户输⼊⼀个要删除的“产地ID”,程序在数组中剔除该条⽬后,将剩余数据重新覆盖写⼊ farms.txt 。⽂件操作重点:使⽤ “r” 模式读取, feof() 或 fscanf() != EOF 判断⽂件结尾。删除逻辑:在内存(数组)中完成删除,再通过重新打开⽂件并写⼊来实现“物理删除”。
💡 说明:

数据⽐较重要,删除前先进⾏确认!
⽂件⽆法像数据库那样直接“删除”某⾏,标准的做法是:将⽂件全部读⼊内存数组 → 在数组中剔除⽬标条⽬ → 以“w”模式重新打开⽂件覆盖写⼊。

#include<stdio.h>#include<string.h>#include<stdlib.h>typedefstruct{intid;charname[50];intyield;}OrangeFarm;intmain(){OrangeFarm farms[100];intcount=0;intdeleted;charconfirm;FILE*fp;fp=fopen("farms.txt","r");if(fp==NULL){printf("错误:无法打开farms.txt,请确保文件已存在。\n");return1;}while(fscanf(fp,"%d %s %d",&farms[count].id,farms[count].name,&farms[count].yield)==3){count++;}fclose(fp);if(count==0){printf("数据库为空,无数据可删除。\n");return0;}printf("\n---当前廉江红橙产地列表---\n");for(inti=0;i<count;i++){printf("[%d] % -12s",farms[i].id,farms[i].name);if((i+1)%3==0){printf("\n");}}printf("\n------------------\n");printf("请输入要删除的产地 ID:");scanf("%d",&deleteld);inttargetlndex=-1;for(inti=0;i<count;i++){if(farms[i].id==deleteld){targetlndex=1;break;}}if(targetlndex==-1){printf("错误:未找到ID为 %d 的记录。\n",deleteld);return0;}printf("\n拟删除记录详情:\n");printf("ID: %d | 名称: %s | 产量: %d 吨\n",farms[targetlndex].id,farms[targetlndex].name,farms[targetlndex].yield);printf("警告:此操作不可撤回!确定删除吗?(y/n):");getchar();scanf("%c",&confirm);if(confirm!='y'&&confirm!='Y'){printf("操作已安全取消。\n");return0;}for(inti=targetlndex;i<count-1;i++){farms[i]=farms[i+1];}count--;fp=fopen("farms.txt","w");if(fp==NULL){printf("系统错误:无法更新文件数据。\n");return1;}for(inti=0;i<count;i++){fprintf(fp,"%d %s %d\n",farms[i].id,farms[i].name,farms[i].yield);}fclose(fp);printf("成功:ID为 %d 的记录已从系统中能够彻底移除。\n",deleteld);return0;}

题目3:精准更新——加载与修改
【任务】:实现交互式修改。

程序打开⽂件并加载所有 ID 供⽤户预览。
⽤户输⼊⽬标 ID。
程序提⽰⽤户选择修改项(1.修改名称 2.修改产量)。
⽤户输⼊新值后,程序更新数组并同步回⽂件。
⽂件操作重点:掌握“内存加载 -> 修改 -> 重新回写”的完整链路。
要求:利⽤ switch-case 结构处理⽤户的修改选择。

#include<stdio.h>#include<string.h>#include<stdlib.h>typedefstruct{intid;charname[50];intyield;}OrangeFarm;intmain(){OrangeFarm farms[100];intcount=0;inttargetId,choice;FILE*fp;fp=fopen("farms.txt","r");if(fp==NULL){printf("错误:无法打开 farms.txt,请确保文件已存在。\n");return1;}while(fscanf(fp,"%d %s %d",&farms[count].id,farms[count].name,&farms[count].yield)==3){count++;}fclose(fp);if(count==0){printf("数据库为空,请先添加数据。\n");return0;}printf("--- 当前系统内的产地 ID 列表 ---\n");for(inti=0;i<count;i++){printf("[%d] %-12s",farms[i].id,farms[i].name);if((i+1)%3==0){printf("\n");}}printf("\n-------------------------------\n");printf("请输?您想要修改的产地 ID: ");scanf("%d",&targetId);intindex=-1;for(inti=0;i<count;i++){if(farms[i].id==targetId){index=i;break;}}if(index==-1){printf("未找到 ID 为 %d 的记录。\n",targetId);return0;}printf("\n已锁定产地: %s (产量: %d 吨)\n",farms[index].name,farms[index].yield);printf("1. 修改产地名称\n");printf("2. 修改预计产量\n");printf("3. 取消修改\n");printf("请选择操作 (1-3): ");scanf("%d",&choice);switch(choice){case1:printf("请输入新的名称: ");scanf("%s",farms[index].name);break;case2:printf("请输入新的产量 (吨): ");scanf("%d",&farms[index].yield);break;case3:printf("操作已取消。\n");return0;default:printf("非法输入,操作终止。\n");return0;}fp=fopen("farms.txt","w");if(fp==NULL){printf("回写文件失败!\n");return1;}for(inti=0;i<count;i++){fprintf(fp,"%d %s %d\n",farms[i].id,farms[i].name,farms[i].yield);}fclose(fp);printf("ID 为 %d 的记录已成功更新。\n",targetId);return0;}

题目4:条件检索——读取与查询
【任务】:编写⼀个查询⼯具。⽤户输⼊⼀个“产量阈值”,程序打开⽂件读取数据,通过遍历结构体数组,筛选并打印出所有产量⼤于该阈值的产地信息。
⽂件操作重点:使⽤循环配合 fscanf 逐⾏解析数据。
逻辑重点:考查结构体成员的访问与逻辑判断表达式。

#include<stdio.h>#include<stdlib.h>typedefstruct{intid;charname[50];intyield;}OrangeFarm;intmain(){FILE*fp;OrangeFarm temp;intthreshold;intfoundCount=0;fp=fopen("farms.txt","r");if(fp==NULL){printf("错误:无法打开数据文件 farms.txt,请确保文件已存在。\n");return1;}printf("----------- 廉江红橙产量筛选系统 -----------\n");printf("请输?产量阈值(吨):");if(scanf("%d",&threshold)!=1){printf("输??效。\n");fclose(fp);// 记得关闭?件return1;}printf("\n正在查询产量大于 %d 吨的产地...\n",threshold);printf("-------------------------------------------\n");printf("%-10s %-20s %-10s\n","ID","产地名称","预计产量(吨)");printf("-------------------------------------------\n");while(fscanf(fp,"%d %s %d",&temp.id,temp.name,&temp.yield)==3){if(temp.yield>threshold){printf("%-10d %-20s %-10d\n",temp.id,temp.name,temp.yield);foundCount++;}}if(foundCount==0){printf("未找到产量超过 %d 吨的记录。\n",threshold);}else{printf("-------------------------------------------\n");printf("查询完毕,共找到 %d 条记录。\n",foundCount);}fclose(fp);return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/25 14:41:44

WarcraftHelper终极指南:魔兽争霸III现代化兼容性优化方案

WarcraftHelper终极指南&#xff1a;魔兽争霸III现代化兼容性优化方案 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 项目价值与痛点解析 魔兽争霸I…

作者头像 李华
网站建设 2026/2/23 16:30:32

Display Driver Uninstaller:彻底清理显卡驱动的终极工具

Display Driver Uninstaller&#xff1a;彻底清理显卡驱动的终极工具 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-uninstall…

作者头像 李华
网站建设 2026/2/26 5:58:17

罗技鼠标宏终极压枪配置:从零到精通的完整指南

还在为绝地求生中难以控制的武器后坐力而困扰吗&#xff1f;罗技鼠标宏压枪功能能够帮你实现稳定射击&#xff0c;告别枪口上跳的烦恼。本指南将手把手教你从安装到实战的全流程配置&#xff0c;即使是零基础的新手也能轻松掌握。 【免费下载链接】logitech-pubg PUBG no recoi…

作者头像 李华
网站建设 2026/2/25 9:48:09

SMUDebugTool完整使用教程:解锁AMD Ryzen处理器的终极性能潜力

SMUDebugTool完整使用教程&#xff1a;解锁AMD Ryzen处理器的终极性能潜力 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: ht…

作者头像 李华
网站建设 2026/2/24 12:06:56

输入法词库转换终极指南:跨平台同步完整解决方案

输入法词库转换终极指南&#xff1a;跨平台同步完整解决方案 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 还在为不同设备间输入习惯不统一而烦恼吗&#xff1f;深…

作者头像 李华
网站建设 2026/2/20 13:32:25

Lucky Draw抽奖系统:企业年会零基础使用指南

Lucky Draw是一款基于Vue.js开发的轻量级抽奖程序&#xff0c;专为企业年会、营销活动等场景设计。该系统支持自定义抽奖规则、数据本地存储和结果展示&#xff0c;无需后端服务即可快速部署使用。无论您是技术新手还是普通用户&#xff0c;都能在几分钟内掌握这款专业抽奖工具…

作者头像 李华