运用到的函数为:

动态内存分配函数malloc()              比如:char *name=(char *)malloc(20);  相当与c++的new关键字

动态内存释放函数free()                 比如:free(name); 相当于c++的delete关键字

计算数据空间的字节数sizeof()         比如:p1 = (struct A*)malloc(sizeof(struct A));

这个链表很多地方没有加判断,判断字符的输入造成的死循环等等,也就大致的学习一下C的动态建立与C++的区别而已。

#include <stdio.h>
#define LENG sizeof(struct A) struct A
{
int num;
char name[20];
struct A *next;
}; struct A *head = NULL; //头指针
struct A* lb(); //建立链表函数
void cha(struct A *head); //查询函数
struct A* charu(struct A* head); //插入函数
struct A* Delete(struct A*head,int x); //删除函数 int main()
{
int y;
int x = 0; while (1)
{
printf("(1)建立链表(2)查询链表(3)插入(4)删除(5)退出\n");
scanf_s("%d", &y);
switch (y)
{
case 1:head = lb();
break;
case 2:cha(head);
break;
case 3:head = charu(head);
break;
case 4:
if (head == NULL)
{
printf("您的链表为空\n");
break;
}
printf("请输入要删除的编号:");
scanf_s("%d", &x);
head = Delete(head,x);
break;
case 5:break;
default:
printf("输入错误请重新输入\n");
continue;
}
if (y == 5)break;
}
system("pause");
return 0;
} struct A* lb()
{
struct A *p1=NULL, *p2=NULL;
int a, b, c;
p1 = p2 = (struct A*)malloc(LENG);
head = p1;
printf("请输入编号:");
scanf_s("%d", &p1->num);
printf("请输入姓名:");
scanf_s("%s", p1->name, 20); while (1)
{
p1 = (struct A*)malloc(LENG);
printf("请输入编号0为结束:");
scanf_s("%d", &a);
if (a == 0)
{
free(p1);
p2->next = NULL;
break;
}
p1->num = a;
printf("请输入姓名:");
scanf_s("%s", p1->name, 20);
p2->next = p1;
p2 = p1;
}
return head;
} void cha(struct A *head)
{
while (1)
{
if (head == NULL)
{
printf("您的链表为空\n");
break;
} printf("%d\t%s\n", head->num, head->name);
if (head->next == NULL)
{
break;
}
head = head->next;
}
} struct A* charu(struct A* head)
{
struct A *p1, *p2, *p3;
p1 = (struct A*)malloc(sizeof(struct A));
p2 = head;
printf("请输入编号:");
scanf_s("%d", &p1->num);
printf("请输入姓名:");
scanf_s("%s", p1->name, 20); if (head->num > p1->num)
{
p1->next = head;
return p1;
}
p3 = head; while (1)
{
if (p1->num < head->num)
{
p1->next = head;
p3->next = p1;
break;
}
else
{
p3 = head;
if (head->next == NULL)
{
head->next = p1;
p1->next = NULL;
break;
}
head = head->next;
}
}
return p2;
} struct A* Delete(struct A*head,int x)
{
struct A *p1,*p2;
p1 = p2 = head;
if (head->num == x)
{
p1 = head;
head = head->next;
free(p1);
return head;
} while (1)
{
if (head->num == x)
{
p1->next = head->next;
break;
}
else
{
p1 = head;
head = head->next;
}
}
return p2;
}

  

C的动态链表建立的更多相关文章

  1. 使用C语言描述静态链表和动态链表

    静态链表和动态链表是线性表链式存储结构的两种不同的表示方式. 静态链表的初始长度一般是固定的,在做插入和删除操作时不需要移动元素,仅需修改指针,故仍具有链式存储结构的主要优点. 动态链表是相对于静态链 ...

  2. C语言习题 链表建立,插入,删除,输出

    Problem B: C语言习题 链表建立,插入,删除,输出 Time Limit: 1 Sec  Memory Limit: 128 MB Submit: 222  Solved: 92 [Subm ...

  3. YTU 2430: C语言习题 链表建立,插入,删除,输出

    2430: C语言习题 链表建立,插入,删除,输出 时间限制: 1 Sec  内存限制: 128 MB 提交: 576  解决: 280 题目描述 编写一个函数creatlink,用来建立一个动态链表 ...

  4. vc++基础班[28]---动态数组及动态链表的讲解

    C++中也有相应的动态数组.动态链表.映射表的模板类,就是STL中的:vector.list.map 他们属于C++标准中的一部分,对于程序的移植性来说也是不错的,但是在MFC编程中使用 CArray ...

  5. HDU 2095 find your present (2) 动态链表

    解题报告:输入一个n,后面紧跟着输入n个数,输入的这n个数中,除了有一个数的个数为奇数外,其它的数的个数都是偶数个,现在要你找出这个个数为奇数的这个数. 看起来好像很简单的样子,不过,这题的重点不在这 ...

  6. C++ 数据结构模板 队列 栈 动态链表 模板 Queue Stack List

    C++数据结构模板,可以实现基本功能,用法和stl差不多,比如Q.pop();Q.push(a);Q.front();...... (由于动态链表用的不多,若有错误望各位大神不吝赐教:) 队列: cl ...

  7. 01--数据结构——动态链表(C++)

    数据结构——动态链表(C++)   定义一个节点: [cpp] view plain copy   print? #include <iostream> using namespace s ...

  8. 20140502 static_cast和dynamic_cast的类型检查 双链表建立,删除,打印

    1.static_cast和dynamic_cast的类型检查 static_cast的类型检查:只检查无关类之间的转换 CBaseY* pY1 = static_cast<CBaseY*> ...

  9. C++ -> 在使用动态链表和异质链表产生野指针的步骤

    C++ -> 在使用动态链表和异质链表产生野指针的步骤 使用异质链表产生野指针的情况,下面是修改书本的例子: ------------------------------------------ ...

随机推荐

  1. UVA 10129 Play on Words(欧拉道路)

    题意:给你n个字符串,问你是否可以出现一条链,保证链中每个字符串的第一个元素与上一个字符串的最后一个元素相同,注意可能重复出现同一个字符串 题解:以每一个字符串第一个元素指向最后一个元素形成一个有向图 ...

  2. bootstrap-datetimepicker日期控件下载

    bootstrap-datetimepicker.js bootstrap-datetimepicker.zh-CN.js bootstrap-datetimepicker.min.css 下载网站: ...

  3. 自学Jav测试代码三 Math类 & Date & GregorianCalendar类

    2017-08-23 20:30:08 writer: pprp package test; import java.util.Date; import java.util.*; public cla ...

  4. jQuery loop over JSON字符串 – $.each实例

    先来一段简单的javascript对象的遍历: var json = [ {"id":"1","tagName":"apple&q ...

  5. 利用hash构建HTML切换

    在Web App和Hybrid App横行的时代,为了拥有更好的用户体验,单页面应用顺势而生,单页面应用简称`SPA`,即Single Page Application,就是只有一个HTML页面的应用 ...

  6. led,key通用IO的端口

    1 注意通用IO端口, GPBCON 只能控制一个GPBDAT位(对应的位),而GPBUP可以使能GPBCON.

  7. customs event

    // First create the event var myEvent = new CustomEvent("userLogin", { detail: { username: ...

  8. 微信小程序------联动选择器

    picker 从底部弹起的滚动选择器,现支持五种选择器,通过mode来区分,分别是普通选择器,多列选择器,时间选择器,日期选择器,省市区选择器,默认是普通选择器. 先来看看效果图: 1:普通选择器 m ...

  9. String写时拷贝实现

    头文件部分 1 /* 版权信息:狼 文件名称:String.h 文件标识: 摘 要:对于上版本简易的String进行优化跟进. 改进 1.(将小块内存问题与大块分别对待)小内存块每个对象都有,当内存需 ...

  10. Python3 学习第十四弹: 模块学习六之re模块 + 正则表达式 (转)

    本文转自 AstralWind 的博客:Python正则表达式指南 特来收藏 1. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分.正则表达式是用于处理字符串的强大工具,拥有 ...