#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>

typedef struct Node {
    int data;
    struct Node * pNode
        } NODE,* PNODE;

PNODE create_list();
void show_list(PNODE);
int is_emp(PNODE);
int length_list(PNODE);
int insert_list(PNODE,int,int);
int delete_list(PNODE,int,int *);
void sort_list(PNODE);

int main(void) {

PNODE p = create_list();

sort_list(p);
    insert_list(p,3,99);
    show_list(p);
    int i;
    delete_list(p,3,&i);
     show_list(p);
      printf("\n");
     printf("%d",i);

return 0;

}

int delete_list(PNODE phead ,int pos,int * val){
     PNODE p = phead;
    int i =0;
    while(NULL!=p && i<pos-1) {
        p=p->pNode;
        i++;
    }
     if(i>pos-1|| NULL == p){
        return 0;
    }
    *val = p->pNode->data;

p->pNode=p->pNode->pNode;
    return 1;

}

int insert_list(PNODE phead,int pos,int val){
    PNODE p = phead;
    int i =0;
    while(NULL!=p && i<pos-1) {
        p=p->pNode;
        i++;
    }
    if(i>pos-1|| NULL == p){
        return 0;
    }
    PNODE pnew = (PNODE)malloc(sizeof(NODE));
    PNODE temp;

pnew ->data=val;

temp = p->pNode;
    p->pNode=pnew;
    pnew->pNode = temp;
    return 1;
}

void sort_list(PNODE phead) {
    int i,j,k;
    int len = length_list(phead);
    PNODE p,q;
    for(i=0,p=p->pNode;i<len-1;p=p->pNode,i++) {
        for(j=i+1,q=p->pNode;j<len;q=q->pNode,j++) {
            if(p->data > q->data) {
                k=q->data;
                q->data=p->data;
                p->data=k;
            }
        }
    }
    return;
}

int is_emp(PNODE phead) {
    if(phead -> pNode == NULL) {
        return 1;
    } else {
        return 0;

}

}

int length_list(PNODE phead) {
    int i =0;
    PNODE p = phead->pNode;
    while(NULL != p) {
        p=p->pNode;
        i++;
    }
    return i;
}

PNODE create_list() {
    int length = 0;
    int val=0;
    int i =0;
    printf("input the list len:  ");
    scanf("%d",&length);
    PNODE pHead = (PNODE)malloc(sizeof(NODE));
    PNODE tail=pHead;
    tail->data=0;
    tail->pNode = NULL;

if(NULL == pHead) {
        printf("t is error");
    }

for(i=0; i<length; ++i) {
        printf("the %d  node value:  ",i+1);
        scanf("%d",&val);
        PNODE pnew = (PNODE)malloc(sizeof(NODE));
        pnew ->data=val;
        tail->pNode=pnew;
        pnew->pNode=NULL;
        tail=pnew;

}
    return pHead;
}

void show_list(PNODE Plist) {
    PNODE next = Plist->pNode;
    while(NULL != next) {
        printf("%d  ",next->data);
        next = next->pNode;
    }
    printf("\n");

return;
}

C语言实现链表的更多相关文章

  1. C语言之链表

    这两天在复习C语言的知识,为了给下个阶段学习OC做准备,以下的代码的编译运行环境是Xcode5.0版本,写篇博文把昨天复习的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. 关于c语言单项链表尾添加

    犹豫了几天,看了很多大牛写的关于c语言链表,感触很多,终于下定决心,把自己对于链表的理解随之附上,可用与否,自行裁夺.由于作者水平有限也是第一次写,不足之处,竭诚希望得到各位大神的批评指正.制作不易, ...

  5. C语言之链表list

    #include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...

  6. C语言:链表实现的一个实例

    问题:写一个程序输入你一年看过的所有电影以及每部电影的各种信息(简化问题:每部电影只要求输入片名和评价) 链表实现: #include<stdio.h> #include<stdli ...

  7. C语言单链表实现19个功能完全详解

    谢谢Lee.Kevin分享了这篇文章 最近在复习数据结构,想把数据结构里面涉及的都自己实现一下,完全是用C语言实现的. 自己编写的不是很好,大家可以参考,有错误希望帮忙指正,现在正处于编写阶段,一共将 ...

  8. (转)c语言_链表实例讲解(两个经典例子)

    建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. #include <stdio.h>#include <stdlib.h> struct grade {    ...

  9. Javascript模仿C语言的链表实现(增删改查),并且使用控制台输入输出

    Js新手最近在研究Js数据结构,刚好看到链表实现这一块儿,觉得有些资料和自己理解的有冲突,于是借着自己以前一点点C语言的基础,用Javascript模仿了C的链表实现,并且用了process.stdi ...

  10. c语言_链表实例讲解(两个经典例子)

    建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. demo1 // lianbiao.cpp : Defines the entry point for the console app ...

随机推荐

  1. shiro注解@RequiresPermissions多权限任选一参数用法

    @RequiresPermissions(value={"xxx:xxx","xxx:xxx"},logical=Logical.OR)

  2. Oracle数据表转换为Shapefile(二)

    在上一篇博文<Oracle数据表转换为Shapefile(一)>中详细描述了一种基于Oracle数据表生产Shapefile的技术方法,本文同样以详细图解的方式描述一种更便捷的方法来完成同 ...

  3. auc的本质

    AUC的本质 定义 auc是roc曲线下的面积.其中,roc是横坐标为fpr,纵坐标是tpr的坐标系上的曲线. TPR(true positive rate):所有正样本中被预测为正的比例 FPR(f ...

  4. 南昌网络赛 I. Max answer 单调栈

    Max answer 题目链接 https://nanti.jisuanke.com/t/38228 Describe Alice has a magic array. She suggests th ...

  5. ajax使用向Spring MVC发送JSON数据出现 org.springframework.web.HttpMediaTypeNotSupportedException: Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported错误

    ajax使用向Spring MVC发送JSON数据时,后端Controller在接受JSON数据时报org.springframework.web.HttpMediaTypeNotSupportedE ...

  6. 洛谷P5273 【模板】多项式幂函数 (加强版)

    题面 传送门 题解 这里最麻烦的问题就是它不保证\(A_0=1\) 如果\(A_0>1\),那么直接整个多项式乘上个\(A_0\)的逆元,最后输出答案的时候再把答案乘上\({A_0}^m\) 如 ...

  7. mycat 1.6.6.1安装以及配置docker 安装mysql 5.7.24 双主多从读写分离主主切换

    mycat和mysql的高可用参考如下两个图 简介:应用程序仅需要连接HAproxy或者mycat,后端服务器的读写分离由mycat进行控制,后端服务器数据的同步由MySQL主从同步进行控制. 服务器 ...

  8. redis 3.0 集群__配置文件详解(常用配置)

    参考文档 http://www.cnblogs.com/huangjacky/p/3700473.html http://www.cnblogs.com/cxd4321/archive/2012/12 ...

  9. TCP 的保活定时器

    引言 可以没有任何数据流过一个空闲的 TCP 连接. 这意味着我们可以启动一个客户与服务器建 立一个连接,然后离去数小时.数天.数个星期或者数月,而连接依然保持.中间路由器可以崩溃和重启,电话线可以被 ...

  10. 傻瓜式学Python3——列表

    前言: 好久不见,突然发觉好久没写博客了,最近迷上了 Python 无法自拔,了解了一下,Python 简单易学,尤其是接触过java的人,入门 Python 更是门槛极低,本着学习记录的原则,边学习 ...