c语言的一个简单的链表
此程序为作业题:
但不忍丢弃成果;
所以记一下:
哦,对了,有一个易错点:在链表里,字符要用字符数组,不能用单个字符。
#include<stdio.h>
#include<stdio.h>
struct menu * head;
int n=0;
struct menu
{
 char name[10];
 int no;
 struct menu* next;
 }; 
 void add()
 {
  struct menu* p1,*p2;
  p1=p2=(struct menu*)malloc(sizeof(struct menu));
  head->next=p1;
  printf("按(0,0)结束\n");
  printf("请输入菜名和价格\n");
  scanf("%s%d",p2->name,&p2->no);
  while(p2->no!=0)
  {
  n=n+1;
  p1->next=p2;
  p1=p2;
  p2=(struct menu*)malloc(sizeof(struct menu));
  scanf("%s%d",p2->name,&p2->no);
  }
  p1->next=NULL;
 }
 void print()
 {
  struct menu* p1;
  p1=head->next;
  while(p1!=NULL)
  {
   printf("%s\t%d\n",p1->name,p1->no);
   p1=p1->next;
  }
 }
 void cha_ru()
 {
  int i,a;
 struct menu *p1,*p2; 
 p1=p2=(struct menu *)malloc(sizeof(struct menu));
 p1=head;
 printf("请输入你要插入的节点前的位置");
 scanf("%d",&a);
 for(i=0;i<a-1;i++)
 p1=p1->next;
 scanf("%s%d",p2->name,&p2->no);
 p2->next=p1->next;
 p1->next=p2;
}
void shanchu()
{
 int i,a;
 struct menu *p1;
 p1=(struct menu *)malloc(sizeof(struct menu));
 p1=head;
 printf("请输入你要删除的位置\n");
 scanf("%d",&a);
 for(i=0;i<a-1;i++) 
 p1=p1->next;
 p1->next=p1->next->next;
}
 int main()
 {
  int a=0;
   head=(struct menu*)malloc(sizeof(struct menu));
  head->next=NULL;
  printf("请输入你要的功能\n");
  printf("输入按1\n输出按2\n删除按3\n插入按4\n");
  while(1)
{
   scanf("%d",&a);
   switch(a)
   {
    case 1:add();break;
    case 2:print();break;
    case 3:shanchu();break;
    case 4:cha_ru();break;
   }
   if(a==' ')
   break;
    printf("请继续你要的功能\n");
  }
c语言的一个简单的链表的更多相关文章
- 用C语言编写一个简单的词法分析程序
		
问题描述: 用C或C++语言编写一个简单的词法分析程序,扫描C语言小子集的源程序,根据给定的词法规则,识别单词,填写相应的表.如果产生词法错误,则显示错误信息.位置,并试图从错误中恢复.简单的恢复方法 ...
 - 用Go语言实现一个简单的聊天机器人
		
一.介绍 目的:使用Go语言写一个简单的聊天机器人,复习整合Go语言的语法和基础知识. 软件环境:Go1.9,Goland 2018.1.5. 二.回顾 Go语言基本构成要素:标识符.关键字.字面量. ...
 - 用 C 语言编写一个简单的垃圾回收器
		
人们似乎觉得编写垃圾回收机制是非常难的,是一种仅仅有少数智者和Hans Boehm(et al)才干理解的高深魔法.我觉得编写垃圾回收最难的地方就是内存分配,这和阅读K&R所写的malloc例 ...
 - 用Verilog语言实现一个简单的MII模块
		
项目中要求简单地测试一下基于FPGA的模拟平台的RJ45网口,也就是需要实现一个MII或者RMII模块.看了一下官方网口PHY芯片的官方文档,还是感觉上手有点障碍,想在网络上找些参考代码看看,最后只在 ...
 - 数据结构|-用C#实现一个简单的链表
		
我们知道C#中是没有链表的,我们可以自己实现一个 整个单链表能实现的功能有: 功能 方法 返回值 备注 获取链表长度 GetLength() int 返回值是链表长度 清空链表 Clear() voi ...
 - socket实例C语言:一个简单的聊天程序
		
我们老师让写一个简单的聊天软件,并且实现不同机子之间的通信,我用的是SOCKET编程.不废话多说了,先附上代码: 服务器端server.c #include <stdio.h> #incl ...
 - 【阿菜做实践】利用go语言写一个简单的Pow样例
		
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简单demo.开发IDE用的是JB Golang. 整个项目的文件结构如下: PoWdem ...
 - go 语言实现一个简单的 web 服务器
		
学习Go语言的一些感受,不一定准确. 假如发生战争,JAVA一般都是充当航母战斗群的角色.一旦出动,就是护卫舰.巡洋舰.航母舰载机.预警机.电子战飞机.潜艇等等浩浩荡荡,杀将过去.(JVM,数十个JA ...
 - go语言实现一个简单的登录注册web小程序
		
最近学习golang也有一段时间了,基础差不多学了个大概,因为本人是java程序员,所以对web更感兴趣.根据<go web编程>中的例子改编一个更简单的例子,供新手参考,废话不多说,上菜 ...
 
随机推荐
- 循环遍历DataTable绑定到Table
			
VoteList2.cs: using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...
 - linux中grep命令详解
			
http://jingyan.baidu.com/article/76a7e409e72777fc3b6e158a.html
 - HDU3333 Turing Tree(线段树)
			
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=3333 Description After inventing Turing Tree, 3x ...
 - .net core 基本概念
			
asp.net core 是基于 .net core的,所以能够跨平台. 目前存在.NET Framework (CLR), .NET Core (CoreCLR) or Mono,可根据项目的具体情 ...
 - 如何记录搜索引擎爬行记录php版
			
写博客也有一段时间了,为什么搜索引擎迟迟不收录你的页面呢?想知道每天都有哪些蜘蛛“拜访”你的网站吗?作为一名网站长,有必要知道每天都有哪些蜘蛛爬行过你的网站,以便于了解各搜索引擎蜘蛛爬行频率,对网站进 ...
 - 【Alpha】Daily Scrum Meeting第三次
			
本次随笔调换了展示顺序,把重要的内容放前面. 一.本次Daily Scrum Meeting主要内容 说明要完成alpha版本还需要哪些功能 对这些功能进行分析和实现方式的讨论 强调编码规范和变量命名 ...
 - 局域网内利用gitlab,jenkins自动生成gitbook并发布(nginx)
			
安装了GitBook,内网使用,没法用上gitbook的网页. 用gitbook serve只能展示一本书,而且也不利于长期维护. 于是使用gitlab,jenkins,和nginx配合gitbook ...
 - EF Code First之困扰
			
Code First自动更新数据库有几种方法 Code First什么都不做 Database.SetInitializer<ShopContext>(null); 发布网站的话一般要在A ...
 - 四则运算之Right-BICEP测试
			
Right-结果是否正确? 正确 B-是否所有的边界条件都是正确的? Conformance(一致性):值是否和预期的一致 是一致的 Ordering(顺序性):值是否如应该的那样 是 是有序或者无 ...
 - 树莓派+移动硬盘搭建NAS服务器
			
由于树莓派的USB接口不足以给移动硬盘供电,因此需要另外给移动硬盘提供电源. 显示当前已有的存储设备 # fdisk -l Disk /dev/mmcblk0: 7876 MB, 7876902912 ...