尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

c语言实验4

c语言实验4
📅 发布时间:2026/6/18 16:15:21

物联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;}

相关新闻

  • 突破Fiji启动瓶颈:Windows系统首启延迟8大解决方案全解析
  • 如何快速掌握XXMI启动器:游戏模组管理的终极解决方案
  • Jasminum插件:中文文献管理的终极解决方案指南

最新新闻

  • CANN/asc-devkit L1到L0A Mx矩阵搬运
  • 福州靠谱二手腕表回收推荐,资质齐全实体门店可上门交易 - 讯息早知道
  • WorkshopDL:5分钟快速上手,免Steam客户端下载创意工坊模组
  • 微信小程序地址选择器:数据驱动下的省市区三级联动架构解析
  • ComfyUI TTP Toolset未来 roadmap:即将支持的SD3模型与动态切片功能预览
  • S12Z BDC硬件握手协议:非侵入式调试与ACK脉冲机制详解

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号