#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define PATH "baocun"
typedef struct SPB
{
int seller_num;
int fit_num;
int building_num;
int count;
struct SPB* next;
} ListNode, * LinkList;
int main()
{ int i;
struct SPB* head = (struct SPB*)malloc(sizeof(struct SPB));
if (head == NULL)
{
printf("分配失败,程序结束");
exit(0);
}
head->next = NULL;
struct SPB* p = NULL;
p=head;
int ch = 0;
while (ch != 7)
{
printf("\nMUNU\n");//菜单
printf("add data---------1\n"); //增加
printf("delete data------2\n"); //删除
printf("update data------3\n"); //修改
printf("insert data------4\n"); //插入
printf("print linklist---5\n"); //输出
printf("baocun-----------6\n"); //保存
printf("exit ------------7\n"); //退出
printf("***********\n\n");
printf("请输入你的选择:");
scanf("%d", &ch);
if (ch == 1)
{
struct SPB pb; //struct SPB pf, * pb;
int i;
if (head == NULL)
continue;
else {
p = head;
while (p->next) p = p->next;
}
for (i = 0; i < 2; i++)
{
pb = (struct SPB*)malloc(sizeof(struct SPB));
if (NULL == pb)
{
printf("malloc fail!\n");
break; //return head;
}
pb->next = NULL;
printf("\nseller's number: ");
scanf("%d", &pb->seller_num);
printf("fit's number: ");
scanf("%d", &pb->fit_num);
printf("builiding's number: ");
scanf("%d", &pb->building_num);
printf("count's number: ");
scanf("%d", &pb->count);
p->next = pb;
p = pb;
}
}if (ch == 2)
{
int i, j = 0;
struct SPB q = NULL;
if (head == NULL)
continue;
else {
p = head;
}
do {
printf("请输入需删除的项:");
scanf("%d", &i);
} while (i <= 0);
while (p && j < i)
{
q = p;
p = p->next;
j++;
}
if (p == NULL)
printf("\n未找到删除的项.\n");
else {
q->next = p->next;
free(p);
printf("\n第%d项删除成功.\n", i);
}
}
if (ch == 3)
{
int i, j = 0;
if (head == NULL)
continue;
else {
p = head;
}
do {
printf("请输入需修改的项:");
scanf("%d", &i);
} while (i <= 0);
while (p && j < i)
{
p = p->next;
j++;
}
if (p == NULL)
printf("\n未找到修改的项.\n");
else {
int sel;
do {
printf("\n请输入你要修改的数据 1,销售商号码 2,配件号 3,工地号 4,数量 :");
scanf("%d", &sel);
} while (sel < 1 || sel>4);
switch (sel) {
case 1:
printf("请输入新的销售商品号:");
scanf("%d", &p->seller_num);
break;
case 2:
printf("请输入新的配件号:");
scanf("%d", &p->fit_num);
break;
case 3:
printf("请输入新的工地号:");
scanf("%d", &p->building_num);
break;
case 4:
printf("请输入新的数量:");
scanf("%d", &p->count);
break;
default:
break;
}
printf("\n第%d项数据修改成功.\n", i);
}
}
if (ch == 4)
{
int i, j = 0;
if (head == NULL)
continue;
else {
p = head;
}
struct SPB q = NULL, * ib = (struct SPB)malloc(sizeof(struct SPB));
ib->next = NULL;
do {
printf("请输入插入的项序号(前插):");
scanf("%d", &i);
} while (i <= 0);
printf("\n请输入插入项的数据:\n");
printf("\nseller's number: ");
scanf("%d", &ib->seller_num);
printf("fit's number: ");
scanf("%d", &ib->fit_num);
printf("builiding's number: ");
scanf("%d", &ib->building_num);
printf("count's number: ");
scanf("%d", &ib->count);
while (p && j < i)
{
q = p;
p = p->next;
j++;
}
if (p == NULL)
q->next = ib;
else {
ib->next = q->next;
q->next = ib;
}
printf("\n第%d项插入成功.\n", i);
}
if (ch == 5)
{
if (head->next == NULL)
continue;
else {
p = head->next;
}
printf("\n1.销售商号码\t2.配件号\t3.工地号\t4.数量\n");
while (p)
{
printf("%d\t\t%d\t\t%d\t\t%d\n", p->seller_num, p->fit_num, p->building_num, p->count);
p = p->next;
}
}
}
if(ch==6)
{
if (head == NULL)
{
printf("节点为空,保存失败\n%s\t%d\t%s\n", FILE, LINE, func);
}
//打开文件
FILE fp = fopen(PATH, "w");
if (fp == NULL)
{
printf("打开文件失败\n");
}
//保存操作
struct SPB bc = head->next;
while (bc != NULL)
{
fprintf(fp,"%d",bc->seller_num);
fprintf(fp,"%d",bc->fit_num);
fprintf(fp,"%d",bc->fit_num);
fprintf(fp,"%d",bc->building_num);
fprintf(fp,"%d",bc->count);
bc = bc->next;
}
//收尾处理
fclose(fp);
fp = NULL;
printf("保存成功");
}
return 0;
free(p);
}
求能把数据保存到文件的功能,和最后把链表释放
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- togolife 2021-12-19 21:31关注
#include <stdio.h> #include <string.h> #include <stdlib.h> #define PATH "baocun" typedef struct SPB { int seller_num; int fit_num; int building_num; int count; struct SPB *next; } ListNode, *LinkList; int main() { int i; struct SPB *head = (struct SPB *)malloc(sizeof(struct SPB)); if (head == NULL) { printf("分配失败,程序结束"); exit(0); } head->next = NULL; struct SPB *p = NULL; p = head; int ch = 0; while (ch != 7) { printf("\nMUNU\n"); //菜单 printf("add data---------1\n"); //增加 printf("delete data------2\n"); //删除 printf("update data------3\n"); //修改 printf("insert data------4\n"); //插入 printf("print linklist---5\n"); //输出 printf("baocun-----------6\n"); //保存 printf("exit ------------7\n"); //退出 printf("***********\n\n"); printf("请输入你的选择:"); scanf("%d", &ch); if (ch == 1) { struct SPB *pb; //struct SPB pf, * pb; int i; if (head == NULL) continue; else { p = head; while (p->next) p = p->next; } for (i = 0; i < 2; i++) { pb = (struct SPB *)malloc(sizeof(struct SPB)); if (NULL == pb) { printf("malloc fail!\n"); break; //return head; } pb->next = NULL; printf("\nseller's number: "); scanf("%d", &pb->seller_num); printf("fit's number: "); scanf("%d", &pb->fit_num); printf("builiding's number: "); scanf("%d", &pb->building_num); printf("count's number: "); scanf("%d", &pb->count); p->next = pb; p = pb; } } if (ch == 2) { int i, j = 0; struct SPB *q = NULL; if (head == NULL) continue; else { p = head; } do { printf("请输入需删除的项:"); scanf("%d", &i); } while (i <= 0); while (p && j < i) { q = p; p = p->next; j++; } if (p == NULL) printf("\n未找到删除的项.\n"); else { q->next = p->next; free(p); printf("\n第%d项删除成功.\n", i); } } if (ch == 3) { int i, j = 0; if (head == NULL) continue; else { p = head; } do { printf("请输入需修改的项:"); scanf("%d", &i); } while (i <= 0); while (p && j < i) { p = p->next; j++; } if (p == NULL) printf("\n未找到修改的项.\n"); else { int sel; do { printf("\n请输入你要修改的数据 1,销售商号码 2,配件号 3,工地号 4,数量 :"); scanf("%d", &sel); } while (sel < 1 || sel > 4); switch (sel) { case 1: printf("请输入新的销售商品号:"); scanf("%d", &p->seller_num); break; case 2: printf("请输入新的配件号:"); scanf("%d", &p->fit_num); break; case 3: printf("请输入新的工地号:"); scanf("%d", &p->building_num); break; case 4: printf("请输入新的数量:"); scanf("%d", &p->count); break; default: break; } printf("\n第%d项数据修改成功.\n", i); } } if (ch == 4) { int i, j = 0; if (head == NULL) continue; else { p = head; } struct SPB *q = NULL, *ib = (struct SPB *)malloc(sizeof(struct SPB)); ib->next = NULL; do { printf("请输入插入的项序号(前插):"); scanf("%d", &i); } while (i <= 0); printf("\n请输入插入项的数据:\n"); printf("\nseller's number: "); scanf("%d", &ib->seller_num); printf("fit's number: "); scanf("%d", &ib->fit_num); printf("builiding's number: "); scanf("%d", &ib->building_num); printf("count's number: "); scanf("%d", &ib->count); while (p && j < i) { q = p; p = p->next; j++; } if (p == NULL) q->next = ib; else { ib->next = q->next; q->next = ib; } printf("\n第%d项插入成功.\n", i); } if (ch == 5) { if (head->next == NULL) continue; else { p = head->next; } printf("\n1.销售商号码\t2.配件号\t3.工地号\t4.数量\n"); while (p) { printf("%d\t\t%d\t\t%d\t\t%d\n", p->seller_num, p->fit_num, p->building_num, p->count); p = p->next; } } if (ch == 6) { if (head == NULL) { printf("节点为空,保存失败\n%s\t%d\t%s\n", __FILE__, __LINE__, __func__); } //打开文件 FILE *fp = fopen(PATH, "w"); if (fp == NULL) { printf("打开文件失败\n"); continue; } //保存操作 struct SPB *bc = head->next; while (bc != NULL) { fprintf(fp, "%d ", bc->seller_num); fprintf(fp, "%d ", bc->fit_num); fprintf(fp, "%d ", bc->fit_num); fprintf(fp, "%d ", bc->building_num); fprintf(fp, "%d ", bc->count); fprintf(fp, "\n"); bc = bc->next; } //收尾处理 fclose(fp); fp = NULL; printf("保存成功"); } } // 释放操作 p = head; while (p) { struct SPB *q = p->next; free(p); p = q; } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 vscode问题请教
- ¥50 切换TabTip键盘的输入法
- ¥15 可否在不同线程中调用封装数据库操作的类
- ¥15 微带串馈天线阵列每个阵元宽度计算
- ¥15 keil的map文件中Image component sizes各项意思
- ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
- ¥15 划分vlan后,链路不通了?
- ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
- ¥15 Vue3 大型图片数据拖动排序
- ¥15 Centos / PETGEM