当前位置: 首页 > news >正文

用C语言链表实现图书管理

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct ListNode {int val;//编号char title[50];//书名float price;//价格struct ListNode* next;
};// 在尾部插入节点
struct ListNode* insertAtTail(struct ListNode* head, int val,char mytitle[50],float price) {struct ListNode* new_node = (struct ListNode*)malloc(sizeof(struct ListNode));new_node->val = val;strcpy(new_node->title,mytitle);new_node->price=price;new_node->next = NULL;if (head == NULL) {return new_node;}struct ListNode* p = head;while (p->next != NULL) {p = p->next;}p->next = new_node;return head;
}
void listAll(struct ListNode* head){printf("编号\t书名\t价格\n");struct ListNode* p=head;while(p!=NULL){printf("%d\t%s\t%f", p->val, p->title, p->price);printf("\n");p=p->next;}
}
// 删除指定值的节点
struct ListNode* deleteNode(struct ListNode* head, int val) {struct ListNode* p = head;struct ListNode* prev = NULL;while (p != NULL && p->val != val) {prev = p;p = p->next;}if (p == NULL) {return head;}if (prev == NULL) {head = head->next;} else {prev->next = p->next;}free(p);return head;
}
// 修改指定值的节点的值
struct ListNode* modifyNode(struct ListNode* head, int old_val,char newTitle[50],float newPrice) {struct ListNode* p = head;while (p != NULL && p->val != old_val) {p = p->next;}if (p == NULL) {return head;}strcpy(p->title  ,newTitle);p->price = newPrice;return head;
}
// 查找指定值的节点的位置
int getIndexByVal(struct ListNode* head, int val) {struct ListNode* p = head;int i = 0;while (p != NULL && p->val != val) {p = p->next;i++;}if (p == NULL) {return -1;}return i;
}
int main(){struct ListNode* p=NULL;for (int i = 0; i < 100; i++){printf("%s", "1.插入图书\n");printf("%s", "2.删除图书\n");printf("%s", "3.图书列表\n");printf("%s", "4.修改图书\n");printf("%s", "请输入1或2或3或4:\n");int select;scanf("%d", &select);if (select == 1){int myVal;printf( "请输入编号:\n");scanf("%d", &myVal);printf( "请输入书名:\n");char myTitle[50];scanf("%s", myTitle);printf( "请输入价格:\n");float myPrice;scanf("%f",&myPrice);if(p==NULL){p=insertAtTail(NULL,myVal,myTitle,myPrice);}else{p=insertAtTail(p,myVal,myTitle,myPrice);}}else if(select==3){listAll(p);}else if(select==2){int deleteVal;printf("请输入要删除的图书的编号:\n");scanf("%d",&deleteVal);p=deleteNode(p,deleteVal);}else if(select==4){int modifyVal;printf("请输入要修改的图书的编号:\n");scanf("%d",&modifyVal);if(getIndexByVal(p,modifyVal)==-1){printf("图书不存在");continue;}printf( "请输入书名:\n");char modifyTitle[50];scanf("%s", modifyTitle);printf( "请输入价格:\n");float modifyPrice;scanf("%f",&modifyPrice);p=modifyNode(p,modifyVal,modifyTitle,modifyPrice);}}return 0;
}

要改成班级管理,ListNode中val不变,其它属性变成学生姓名、成绩等等。
注意:c语言的编译不要用visual studio,因为它连scanf都会报错,会要求您使用scanf_s。建议用记事本或visual studio code编写,然后在命令行窗口输入gcc命令来编译。

http://www.lryc.cn/news/320327.html

相关文章:

  • Hello,Spider!入门第一个爬虫程序
  • AI实景无人自动直播间怎么搭建?三步教你轻松使用
  • wechaty微信机器人,当机器人被@时做出响应
  • 8.6 Springboot项目实战 Spring Cache注解方式使用Redis
  • rust引用本地crate
  • 分布式(计算机算法)
  • CSS概念及入门
  • 用 C 语言模拟 Rust 的 Result 类型
  • git基础命令(四)之分支命令
  • redis瘦身版
  • 使用ChatGPT高效完成简历制作[中篇]-有爱AI实战教程(五)
  • 论文阅读——SpectralGPT
  • Redis的过期键是如何处理的?过期键的删除策略有哪些?请解释Redis的内存淘汰策略是什么?有哪些可选的淘汰策略?
  • 软件测试方法 -- 等价类边界值
  • LeetCode——贪心算法(Java)
  • 【MySQL】2. 数据库基础
  • 《如何使用C语言去下三子棋?》
  • Linux——线程(4)
  • vite+vue3项目中svg图标组件封装
  • 根据服务器系统选择对应的MySQL版本
  • 【数据结构】栈与队列的“双向奔赴”
  • sqllab第二十七关通关笔记
  • 助推直播产业升级与经济转型 天府锋巢直播产业基地成都开园
  • VSCode+python单步调试库代码
  • 如何使用EMC测试软件执行辐射抗扰度测试?(三)软件检查及手动模式
  • 云手机为电商提供五大出海优势
  • chatgpt大模型基础学习
  • 代码随想录算法训练营第14天 part01 | 二叉树理论基础篇
  • async与defer的区别
  • 奇数乘积(C语言)