运用到的函数为:

动态内存分配函数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. HighCharts 在IE8下饼图不显示的问题

    HighCharts饼图用来做数据统计时,在IE8下发现某些图形不能正确显示出来. 在IE8下面会报  'this.renderer.gradients' 为空或不是对象 这样的错误.. 解决方法: ...

  2. Apache 2 移植到Arm开发板

    第一步,安装pcre: tar -xvzf pcre-8.31.tar.gz cd pcre-8.31 ./configure --prefix=$ARMROOTFS/usr/pcre 的错误,如下图 ...

  3. python 函数、模块、包及import导入方法

    https://www.cnblogs.com/lijunjiang2015/p/7812996.html

  4. git-----初始化配置添加用户名和密码

    Git是分布式版本控制系统,GitHub 是最大的 Git 版本库托管商,是成千上万的开发者和项目能够合作进行的中心. 大部分 Git 版本库都托管在 GitHub,很多开源项目使用 GitHub 实 ...

  5. dom&bom的起源,方法,内容,应用

    Document Object Model的历史可以追溯至1990年代后期微软与Netscape的"浏览器大战"(browser wars),双方为了在JavaScript与JSc ...

  6. 14.并发容器之ConcurrentHashMap(JDK 1.8版本)

    1.ConcurrentHashmap简介 在使用HashMap时在多线程情况下扩容会出现CPU接近100%的情况,因为hashmap并不是线程安全的,通常我们可以使用在java体系中古老的hasht ...

  7. 十四 web爬虫讲解2—Scrapy框架爬虫—豆瓣登录与利用打码接口实现自动识别验证码

    打码接口文件 # -*- coding: cp936 -*- import sys import os from ctypes import * # 下载接口放目录 http://www.yundam ...

  8. AOP(面向切面)的粗俗理解

    百度百科的解释:AOP主要实现的目的是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果. 一个比较绕的概念,简单来说就是把不影响业 ...

  9. UVA-11478 Halum (差分约束系统)

    题目大意:一张n个节点的有向带边权图,每次操作能任选一个节点v个一个整数d,使以v为终点的边权值都减少d,以v为起点的边权值都增加d,求若干次操作后的最小边权值的非负最大值. 题目分析:用sum[i] ...

  10. nyoj20——有向无环图深搜模板

    吝啬的国度 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 在一个吝啬的国度里有N个城市,这N个城市间只有N-1条路把这个N个城市连接起来.现在,Tom在第S号城市, ...