当前位置: 首页 > news >正文

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;}
http://www.rkmt.cn/news/166673.html

相关文章:

  • 突破Fiji启动瓶颈:Windows系统首启延迟8大解决方案全解析
  • 如何快速掌握XXMI启动器:游戏模组管理的终极解决方案
  • Jasminum插件:中文文献管理的终极解决方案指南
  • AI语音转换终极教程:从零开始打造专业声音效果的完整指南
  • 客户迁移成本计算:从其他平台转向TRT优化体系
  • GPU算力产品包装:突出‘出厂即优化’理念
  • Hitboxer SOCD优化工具:终极游戏按键冲突解决方案
  • 5分钟快速配置指南:轻松掌握罗技鼠标压枪宏的核心功能
  • 网页资源下载难题的终极解决方案:猫抓浏览器扩展深度解析
  • AdGuard Home广告拦截全攻略:百万规则打造纯净上网体验
  • 5分钟上手BabelDOC:让PDF文档翻译变得如此简单![特殊字符]
  • 3分钟搞定QQ空间数据备份:手把手教你导出所有历史说说
  • 智能内容解锁完全指南:轻松突破付费墙的终极方案
  • 深蓝词库转换工具完全指南:跨平台输入法词库同步解决方案
  • 终极指南:如何精通猫抓cat-catch的10个高级技巧
  • 大模型服务创新模式:按优化程度分级收费
  • 如何快速提取视频硬字幕:本地OCR工具终极指南
  • 数字内容访问优化技术终极指南:解锁信息自由新时代
  • 视频字幕提取完全指南:本地OCR技术实现多语言字幕识别
  • 终极Windows包管理器解决方案:5分钟搞定Winget安装问题!
  • ComfyUI-Manager 终极指南:轻松管理AI工作流节点
  • JetBrains IDE评估信息重置技术解析
  • NVIDIA驱动深度优化:Profile Inspector进阶使用指南
  • 大麦网抢票神器:DamaiHelper帮你轻松搞定演唱会门票
  • JLink驱动安装方法超详细版:含设备管理器操作
  • 百度网盘直链解析工具:突破限速,实现高速下载新体验
  • 如何用TensorRT支持非Transformer架构大模型?
  • 大模型服务品牌建设:打造‘极速派’技术标签
  • 大模型推理监控大盘设计:重点展示TensorRT指标
  • 如何用TensorRT支持长文本生成场景?