news 2026/3/3 20:29:52

实验四代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
实验四代码

1

/*
project1_add. 增加数据
*/
#include <stdio.h>
#include <stdlib.h>
typedef struct {
int id; // 产地ID
char name[50]; // 产地名称
int yield; // 产量(吨)
} OrangeFarm;
int main() {
OrangeFarm new_farm; // 本次只需定义?个结构体变量?于追加
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,确保下?条追加的数据能另起??
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;
}

2


/*
project2_delete. 删除信息
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct {
int id;
char name[50];
int yield;
} OrangeFarm;
int main() {
OrangeFarm farms[100]; // 假设最多存储100个产地
int count = 0;
int deleteId;
char confirm;
FILE *fp;
// 1. 读取?件内容到内存数组
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;
}
// 2. 像题?3?样,先展?当前所有数据,每?3个并对?
printf("\n--- 当前廉江红橙产地列表 ---\n");
for (int 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");
// 3. ?户输?要删除的 ID
printf("请输?要删除的产地 ID: ");
scanf("%d", &deleteId);
// 查找该 ID 所在的索引
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;
}
// 4. 显?具体信息并进?确认
printf("\n拟删除记录详情:\n");
printf("ID: %d | 名称: %s | 产量: %d 吨\n",
farms[targetIndex].id, farms[targetIndex].name,
farms[targetIndex].yield);
printf("警告:此操作不可撤回!确定删除吗?(y/n): ");

getchar(); // 清除之前输?的换?符,防? scanf 直接读取回?
scanf("%c", &confirm);
if (confirm != 'y' && confirm != 'Y') {
printf("操作已安全取消。\n");
return 0;
}
// 5. 在数组中进?“逻辑删除”
// 将?标位置之后的元素全部向前移动?位
for (int i = targetIndex; i < count - 1; i++) {
farms[i] = farms[i + 1];
}
count--; // 总数减1
// 6. 重新写回?件(覆盖模式)
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;
}

3

/*
project3_alter.修改信息
*/
#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 targetId, choice;
FILE *fp;
// 1.加载数据到内存
fp = fopen("farms.txt", "r");
实验四【⽂件操作】
8
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;
}
// 2.展⽰已有ID,每⾏3个并对⻬
printf("---当前系统内的产地ID列表---\n");
for (int 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");
// 3.⽤户选择要修改的ID
printf("请输⼊您想要修改的产地ID: ");
scanf("%d", &targetId);
int index = -1;
for (int i = 0; i < count; i++) {
if (farms[i].id == targetId) {
index = i;
break;
}
}
实验四【⽂件操作】
9
if (index == -1) {
printf("未找到ID%d的记录。\n", targetId);
return 0;
}
// 4.选择修改项
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) { //使⽤switch-case处理多选项
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;
}
// 5.写回⽂件
fp = fopen("farms.txt", "w");
if (fp == NULL) {
printf("回写⽂件失败!\n");
return 1;
}
实验四【⽂件操作】
10
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;
}

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

如何用TensorRT镜像快速部署Llama 3、ChatGLM等热门模型?

如何用TensorRT镜像快速部署Llama 3、ChatGLM等热门模型&#xff1f; 在大语言模型&#xff08;LLM&#xff09;日益普及的今天&#xff0c;一个看似“能跑”的模型和真正“可用”的服务之间&#xff0c;往往隔着一条由延迟、吞吐量与硬件成本构成的鸿沟。比如你手头有个 Llama…

作者头像 李华
网站建设 2026/2/28 10:04:59

SHELL 脚本单元练习题

1、检测两台服务器指定目录下的文件一致性 dir/data/web # 定义远程服务器的IP&#xff08;B机&#xff09; b_ip192.168.72.128 # 1. 在本地服务器执行&#xff1a;遍历dir目录下的所有文件&#xff0c;生成每个文件的MD5值&#xff0c;保存到本地临时文件 md5_a.txt find…

作者头像 李华
网站建设 2026/2/14 11:09:34

揭秘NVIDIA官方推理黑科技:TensorRT镜像全解析

揭秘NVIDIA官方推理黑科技&#xff1a;TensorRT镜像全解析 在AI模型越来越“重”的今天&#xff0c;一个训练好的神经网络从实验室走向生产环境&#xff0c;往往要经历一场残酷的现实考验。你可能在论文里看到某个模型准确率高达98%&#xff0c;但在真实服务中却因为一次推理耗…

作者头像 李华
网站建设 2026/3/2 21:20:28

举办线下Meetup:聚集本地AI开发者交流实践经验

聚焦本地AI开发者&#xff1a;深入实践TensorRT推理优化技术 在今天&#xff0c;一个训练精度高达95%的图像分类模型&#xff0c;部署上线后却因为每帧处理耗时超过40毫秒而无法满足实时视频分析的需求——这样的场景&#xff0c;在AI工程化落地过程中并不少见。实验室里的SOTA…

作者头像 李华
网站建设 2026/2/25 21:49:27

许可证管理模式:避免因开源协议引发法律纠纷

许可证管理模式&#xff1a;避免因开源协议引发法律纠纷 在人工智能技术加速落地的今天&#xff0c;越来越多的企业将深度学习模型部署到生产环境中&#xff0c;追求极致的推理性能。NVIDIA TensorRT 作为 GPU 加速推理的事实标准之一&#xff0c;凭借其强大的优化能力&#xf…

作者头像 李华
网站建设 2026/3/2 20:44:55

推动标准制定:参与AI推理优化相关行业规范起草

推动标准制定&#xff1a;参与AI推理优化相关行业规范起草 在当今AI模型加速落地的浪潮中&#xff0c;一个现实问题日益凸显&#xff1a;训练阶段表现优异的深度学习模型&#xff0c;一旦进入生产环境&#xff0c;往往“水土不服”——推理延迟高、吞吐量低、资源消耗大。这种…

作者头像 李华