news 2026/1/14 0:43:26

C语言作业·实验四

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言作业·实验四
#include <stdio.h> #include <stdlib.h> typedef struct { int id; // 产地ID char name[50]; // 产地名称 int yield; // 产量(吨) } OrangeFarm; int main() { OrangeFarm new_farm; // 本次只需定义1个结构体变量用于追加 FILE *fp; // 1. 从控制台录入单条需要追加的数据 printf("--- 廉江红橙产地数据追加 ---\n"); printf("请输入新增产地信息(格式:ID 名称 产量):\n"); if (scanf("%d %s %d", &new_farm.id, new_farm.name, &new_farm.yield) != 3) { printf("输入格式错误。\n"); return 1; } // 2. 以追加模式("a")打开文件 // "a" 代表 append。如果文件不存在会创建;如果存在,指针直接指向文件末尾 fp = fopen("farms.txt", "a"); // 检查文件打开是否成功 if (fp == NULL) { printf("错误:无法打开文件进行追加!\n"); return 1; } // 3. 使用fprintf 写入新数据 // 务必保留末尾的 \n,确保下1条追加的数据能另起一行 fprintf(fp, "%d %s %d\n", new_farm.id, new_farm.name, new_farm.yield); // 4. 关闭文件 fclose(fp); printf("\n新记录已成功追加至 farms.txt 末尾。\n"); return 0; }

#include<stdio.h> #include<string.h> #include<stdlib.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main() { OrangeFarm farms[100]; int count = 0; int deleteId; 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--- 当前廉江红橙产地列表 ---\n"); for (int i = 0; i < count; i++) { printf("[%d] %s", farms[i].id, farms[i].name); if ((i + 1) % 3 == 0) { printf("\n"); } } printf("\n---------------------\n"); printf("请输入要删除的产地 ID: "); scanf("%d", &deleteId); int targetIndex = -1; for (int i = 0; i < count; i++) { if (farms[i].id == deleteId) { targetIndex = i; break; } } if (targetIndex == -1) { printf("错误:未找到 ID 为 %d 的记录。\n", deleteId); return 0; } printf("\n拟删除记录详情:\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 (int 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 (int 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", deleteId); return 0; }

#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct { int id; char name[50]; int yield; } OrangeFarm; int main(void) { OrangeFarm farms[100]; int count = 0; int targetId, choice, index; FILE *fp; fp = fopen("farms.txt", "r"); if (fp == NULL) { printf("错误:无法打开 farms.txt,请确保文件已存在。\n"); return 1; } while (fscanf(fp, "%d %49s %d", &farms[count].id, farms[count].name, &farms[count].yield) == 3) { count++; } fclose(fp); if (count == 0) { printf("数据库为空,请先添加数据。\n"); return 0; } printf("\n--- 当前系统内的产地 ID 列表 ---\n"); for (int i = 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); index = -1; for (int 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已锁定产地: %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("%s", 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 (int 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() { FILE *fp; OrangeFarm temp; int threshold; int foundCount = 0; // 1. 打开⽂件进⾏读取 fp = fopen("farms.txt", "r"); if (fp == NULL) { printf("错误:⽆法打开数据⽂件 farms.txt,请确保⽂件已存在。\n"); return 1; } // 2. 获取⽤户查询条件 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"); // 3. 循环逐⾏解析数据 // fscanf 返回成功读取的项⽬数,若达到⽂件末尾则返回 EOF while (fscanf(fp, "%d %s %d", &temp.id, temp.name, &temp.yield) == 3) { // 4. 执⾏逻辑判断与成员访问 if (temp.yield > threshold) { printf("%-10d %-20s %-10d\n", temp.id, temp.name, temp.yield); foundCount++; } } // 5. 结果汇总 if (foundCount == 0) { printf("未找到产量超过 %d 吨的记录。\n", threshold); } else { printf("-------------------------------------------\n"); printf("查询完毕,共找到 %d 条记录。\n", foundCount); } // 6. 必须执⾏的⽂件关闭操作 fclose(fp); return 0; }

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

AI应用架构师指南:超级计算中科研AI智能体的内存优化策略

AI应用架构师指南&#xff1a;超级计算中科研AI智能体的内存优化策略 ![内存优化&#xff1a;超级计算AI的隐形基石] 1. 引入与连接&#xff1a;当智能遇见极限 “Error: Out Of Memory” — 在超级计算中心&#xff0c;这句简单的错误提示可能意味着数周的计算资源预约付诸…

作者头像 李华
网站建设 2026/1/3 20:40:20

YOLOFuse Early Stopping机制:防止过拟合的自动停止训练

YOLOFuse Early Stopping机制&#xff1a;防止过拟合的自动停止训练 在复杂环境下的目标检测任务中&#xff0c;比如夜间监控、烟雾遮挡或低光照场景&#xff0c;模型常常面临一个棘手问题&#xff1a;训练集上表现越来越好&#xff0c;验证集却开始下滑。这种“学得太多反而变…

作者头像 李华
网站建设 2026/1/13 2:26:12

企业级语音服务构建:以CosyVoice3为基础的私有化部署架构设计

企业级语音服务构建&#xff1a;以CosyVoice3为基础的私有化部署架构设计 在金融客服系统中&#xff0c;一条“您的账户余额为XXX元”的语音通知&#xff0c;若由冰冷机械音播报&#xff0c;可能引发用户焦虑&#xff1b;而若用熟悉、温和且带地方口音的声音娓娓道来&#xff0…

作者头像 李华
网站建设 2026/1/5 1:13:00

手动修正CosyVoice3识别结果的方法:提高语音匹配准确度

手动修正CosyVoice3识别结果的方法&#xff1a;提高语音匹配准确度 在当前AI语音技术飞速发展的背景下&#xff0c;声音克隆已不再是实验室里的概念&#xff0c;而是广泛应用于虚拟主播、有声书生成、个性化语音助手等实际场景。阿里开源的 CosyVoice3 凭借其对多语言、多方言和…

作者头像 李华
网站建设 2026/1/5 7:28:07

全面讲解Pspice中非线性电感建模技术

深入Pspice非线性电感建模&#xff1a;从物理本质到工程实战 在电源设计的世界里&#xff0c;有一个令人又爱又恨的现实—— 仿真总是比实测“理想”一点 。尤其是当你在Pspice中跑完一个反激变换器的瞬态分析&#xff0c;看到电流波形光滑如丝&#xff0c;效率高达95%&…

作者头像 李华
网站建设 2026/1/11 21:25:56

YOLOFuse自监督预训练设想:SimCLR风格对比学习

YOLOFuse自监督预训练设想&#xff1a;SimCLR风格对比学习 在低光照、浓雾或烟尘弥漫的环境中&#xff0c;传统基于可见光的目标检测系统常常“失明”——图像模糊、对比度下降&#xff0c;连人眼都难以分辨目标&#xff0c;更别提依赖纹理与颜色信息的深度模型。然而&#xff…

作者头像 李华