当前位置: 首页 > 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.jsqmd.com/news/151585/

相关文章:

  • 魔兽争霸III性能优化实战:让经典游戏在新电脑上焕发新生
  • 输入法词库转换终极指南:跨平台同步完整解决方案
  • Alas终极指南:如何快速实现碧蓝航线全自动托管?
  • 如何快速掌握XXMI启动器:游戏模组管理的终极解决方案
  • Degrees of Lewdity中文汉化终极指南:快速上手完整教程
  • ComfyUI-Manager 完全指南:从零开始掌握AI绘画插件管理
  • 解锁PC游戏新姿势:用DS4Windows让PS手柄变身万能控制器
  • Display Driver Uninstaller终极完整指南:显卡驱动彻底卸载一键清理技巧
  • 终极NVIDIA显卡性能解锁指南:Profile Inspector完全教程
  • 智能内容解锁技术:如何实现付费墙的智能绕过
  • JLink驱动下载官网接入工业PLC系统操作指南
  • Jasminum插件:中文文献管理的终极解决方案指南
  • 一键部署!使用官方TensorRT镜像加速HuggingFace模型
  • Hanime1Plugin:打造Android纯净动画观影新体验
  • 魔兽争霸III性能优化终极指南:从技术原理到实战应用
  • 一键解锁Windows包管理器:winget-install让软件安装从未如此简单
  • Zotero SciPDF插件:智能文献获取的革命性解决方案
  • AI语音转换终极教程:从零开始打造专业声音效果的完整指南
  • Zotero SciPDF插件:科研文献自动获取的终极解决方案
  • 纪念币自动预约工具完全攻略:告别抢币焦虑的终极方案
  • Windows 系统远程桌面多用户访问技术解决方案
  • 绝地求生压枪终极指南:5分钟掌握罗技鼠标宏完美配置
  • Hitboxer SOCD优化器:专业级游戏按键冲突终极解决方案
  • 客户迁移成本计算:从其他平台转向TRT优化体系
  • GPU算力产品包装:突出‘出厂即优化’理念
  • Hitboxer SOCD优化工具:终极游戏按键冲突解决方案
  • Mermaid图表制作:10个让技术文档脱颖而出的秘诀
  • 5分钟快速配置指南:轻松掌握罗技鼠标压枪宏的核心功能
  • HID协议与STM32结合的嵌入式应用全面讲解
  • Display Driver Uninstaller完整操作指南与最佳实践