运用到的函数为:

动态内存分配函数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. ASP.NET.Identity 加密算法

    public static string HashPassword(string password) { if (password == null) { throw new ArgumentNullE ...

  2. linux环境变量 export命令详解

    由host $ export DVSDK="${HOME}/ti-dvsdk_dm368-evm_xx_xx_xx_xx"引发的问题 1.${HOME}:首先, HOME 是个变量 ...

  3. MongoDB开启安全认证

    MongoDB开启安全认证 注意 对MongoDB部署启用访问控制会强制执行身份验证,要求用户识别自己.当访问启用了访问控制的MongoDB部署时,用户只能执行由其角色确定的操作. 启用访问控制后,请 ...

  4. Python+Opencv进行识别相似图片

    http://blog.csdn.net/feimengjuan/article/details/51279629

  5. Angular中form表单中input自动响应回车事件无效

    环境:angular.js 问题:当你在input框中输入搜索信息,然后回车键,信息消失而且也没有执行查询??? 原因:组合查询的代码不是<button ng-click="ch()& ...

  6. Apache的三种工作模式及相关配置

    Apache的三种工作模式 作为老牌服务器,Apache仍在不断地发展,就目前来说,它一共有三种稳定的MPM(Multi-Processing Module,多进程处理模块).它们分别是 prefor ...

  7. UVALive-5713 Qin Shi Huang's National Road System (次小生成树)

    题目大意:有n个城市,要修一些路使得任意两个城市都能连通.但是有人答应可以不计成本的帮你修一条路,为了使成本最低,你要慎重选择修哪一条路.假设其余的道路长度为B,那条别人帮忙修的道路两端城市中的总人口 ...

  8. 普通for循环遍历LinkedList弊端

    java开发过程中,用到的最多的List集合就属ArrayList与LinkedList.对于ArrayList的遍历,通常是下面的方法: public static void main(String ...

  9. js排序算法03——选择排序

    选排序的思路是首先从要排序的数组中选择最小的和目前的第一位交换位置,然后从剩下的数中选择最小的和第二个位置的数交换位置,再从剩下的数中选择最小的和第三个位置的数交换位置,以此类推,实现代码如下: fu ...

  10. Python中字符串、列表、元组、集合、字典中的一些知识,有些不太常见

    ————————笔记——————————# 字符串1. 字符串是不可变的.2. 字符串切片输出:`[start:end:step]`.使用`a[::-1]`倒序输出字符串.3. `str.split( ...