news 2026/5/19 5:21:34

实验四from huanghai

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
实验四from huanghai

#include <stdio.h> #include <stdlib.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { OrangeFarm new_farm; FILE *fp; printf("---廉江红橙产地数据追加---\n"); printf("请输入新增产地信息(格式:ID 名称 产量):\n"); if(scanf("%d %s %d", &new_farm.id, new_farm.name, &new_farm.yield) != 3){ printf("输入格式错误。\n"); return 1; } fp = fopen("farms.txt", "a"); if(fp == NULL){ printf("错误:无法打开文件进行追加!\n"); return 1; } fprintf(fp,"%d %s %d\n", new_farm.id, new_farm.name, new_farm.yield); fclose(fp); printf("\n新纪录已成功追加至farms.txt末尾。\n"); return 0; }

#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { OrangeFarm farms[100]; int count = 0; int deleted; char confirm; FILE *fp; fp = fopen("farms.txt","r"); if(fp == NULL){ printf("错误:无法打开farms.txt,请确保文件已存在。\n"); return 1; } while(fscanf(fp,"%d %s %d", &farms[count].id, farms[count].name, &farms[count].yield) == 3){ count++; } fclose(fp); if(count == 0){ printf("数据库为空,无数据可删除。\n"); return 0; } printf("---当前廉江红橙产地列表---\n"); int i; for(i = 0; i < count; i++){ printf("[%d] %-12s", farms[i].id, farms[i].name); if((i + 1) % 3 == 0){ printf("\n"); // 每行输出3个后换行 } } printf("\n---------------------------\n"); printf("请输入要删除的产地ID:"); scanf("%d", &deleted); int targetIndex = -1; for(i = 0; i < count; i++){ if(farms[i].id == deleted){ targetIndex = i; break; } } if(targetIndex == -1){ printf("错误:未找到ID为%d的记录。\n", deleted); return 0; } printf("拟删除记录详情:\n"); printf("ID:%d|名称:%s|产量:%d吨\n", farms[targetIndex].id, farms[targetIndex].name, farms[targetIndex].yield); printf("警告:此操作不可撤回!确定删除吗?(y/n):"); getchar(); scanf("%c", &confirm); if(confirm != 'y' && confirm !='Y'){ printf("操作已安全取消。\n"); return 0; } for(i = targetIndex; i < count - 1; i++){ farms[i] = farms[i + 1]; } count--; fp = fopen("farms.txt","w"); if(fp == NULL){ printf("系统错误:无法更新文件数据。\n"); return 1; } for(i = 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", deleted); return 0; }

#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { OrangeFarm farms[100]; int count = 0; int targetId, choice; FILE *fp; fp = fopen("farms.txt","r"); if(fp == NULL){ printf("错误:无法打开farms.txt,请确保文件已存在。\n"); return 1; } while(fscanf(fp,"%d %s %d", &farms[count].id, farms[count].name, &farms[count].yield) == 3){ count++; } fclose(fp); if(count == 0){ printf("数据库为空,请先添加数据。\n"); return 0; } printf("---当前系统内的产地ID列表---\n"); int i; for(i = 0; i < count; i++){ printf("[%d] %-12s", farms[i].id, farms[i].name); // %-12s 保证名称左对齐 if((i + 1) % 3 == 0){ printf("\n"); // 每行输出3个后换行 } } printf("\n---------------------------\n"); printf("请输入您想要修改的产地ID:"); scanf("%d", &targetId); int index = -1; for(i = 0; i < count; i++){ if(farms[i].id == targetId){ index = i; break; } } if(index == -1){ printf("未找到ID为%d的记录。\n", targetId); return 0; } printf("\n已锁定产地ID:%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){ case 1: printf("请输入新的名称:"); scanf("%d", farms[index].name); break; case 2: printf("请输入新的产量(吨):"); scanf("%d", &farms[index].yield); break; case 3: printf("操作已取消。\n"); return 0; default: printf("非法输入,操作终止。\n"); return 0; } fp = fopen("farms.txt","w"); if(fp == NULL){ printf("回写文件失败!\n"); return 1; } for(i = 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); return 0; }

#include <stdio.h> #include <stdlib.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { OrangeFarm temp; int foundCount = 0; int threshold;//阈值 FILE *fp; fp = fopen("farms.txt","r"); if(fp == NULL){ printf("错误:无法打开farms.txt,请确保文件已存在。\n"); return 1; } printf("----------- 廉江红橙产量筛选系统 -----------\n"); printf("请输入产量阈值(吨):"); if(scanf("%d", &threshold) != 1){ printf("输入无效。\n"); fclose(fp);//记得关文件 return 1; } 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 %-20d %-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); return 0; }

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 3:04:35

从 ABP 到 CleanDDD:关于软件长期演进的一些思考

从 ABP 到 CleanDDD&#xff1a;关于软件长期演进的一些思考 最近在项目中接触到了 CleanDDD&#xff0c;也重新审视了我们长期使用的 ABP 技术栈。 这并不是一篇“反 ABP”的文章&#xff0c;而是一次站在时间维度上的技术反思。 如果你也在维护一个已经运行多年、并且还会继续…

作者头像 李华
网站建设 2026/5/14 15:37:36

为什么选择TensorFlow 2.9镜像进行大模型训练?

为什么选择TensorFlow 2.9镜像进行大模型训练&#xff1f; 在当前AI研发加速迈向工业化和规模化的背景下&#xff0c;一个稳定、高效且可复现的开发环境&#xff0c;往往比模型结构本身更能决定项目的成败。尤其是在大模型训练场景中&#xff0c;动辄数百GB显存占用、跨多卡甚至…

作者头像 李华
网站建设 2026/5/15 9:01:43

监控TensorFlow训练任务状态:Prometheus集成方案

监控TensorFlow训练任务状态&#xff1a;Prometheus集成方案 在现代深度学习项目中&#xff0c;一次模型训练可能持续数小时甚至数天。你有没有遇到过这样的场景&#xff1a;提交任务后只能干等结果&#xff0c;偶尔查看日志发现损失值早已不再下降&#xff0c;却无法第一时间察…

作者头像 李华
网站建设 2026/5/1 1:35:36

JAVA助力:同城羽毛球馆自助预约新方案

JAVA助力&#xff1a;同城羽毛球馆自助预约新方案一、方案背景与目标在全民健身热潮下&#xff0c;羽毛球作为一项广受欢迎的体育运动&#xff0c;其场馆预约需求日益增长。传统的人工预约方式存在效率低、信息不透明、管理成本高等问题。本方案旨在利用JAVA技术&#xff0c;打…

作者头像 李华
网站建设 2026/5/15 14:15:20

远程访问TensorFlow开发环境:SSH配置图文教程

远程访问TensorFlow开发环境&#xff1a;SSH配置实战指南 在深度学习项目中&#xff0c;你是否曾遇到这样的场景&#xff1f;本地笔记本跑不动模型&#xff0c;训练一次要十几个小时&#xff1b;团队成员之间因为环境版本不一致导致代码“在我机器上能跑”&#xff1b;或者你想…

作者头像 李华