C语言实现链表
#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语言实现链表的更多相关文章
- C语言之链表
这两天在复习C语言的知识,为了给下个阶段学习OC做准备,以下的代码的编译运行环境是Xcode5.0版本,写篇博文把昨天复习的C语言有关链表的知识给大家分享一下,以下是小菜自己总结的内容,代码也是按照自 ...
- C语言习题 链表建立,插入,删除,输出
Problem B: C语言习题 链表建立,插入,删除,输出 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 222 Solved: 92 [Subm ...
- YTU 2430: C语言习题 链表建立,插入,删除,输出
2430: C语言习题 链表建立,插入,删除,输出 时间限制: 1 Sec 内存限制: 128 MB 提交: 576 解决: 280 题目描述 编写一个函数creatlink,用来建立一个动态链表 ...
- 关于c语言单项链表尾添加
犹豫了几天,看了很多大牛写的关于c语言链表,感触很多,终于下定决心,把自己对于链表的理解随之附上,可用与否,自行裁夺.由于作者水平有限也是第一次写,不足之处,竭诚希望得到各位大神的批评指正.制作不易, ...
- C语言之链表list
#include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...
- C语言:链表实现的一个实例
问题:写一个程序输入你一年看过的所有电影以及每部电影的各种信息(简化问题:每部电影只要求输入片名和评价) 链表实现: #include<stdio.h> #include<stdli ...
- C语言单链表实现19个功能完全详解
谢谢Lee.Kevin分享了这篇文章 最近在复习数据结构,想把数据结构里面涉及的都自己实现一下,完全是用C语言实现的. 自己编写的不是很好,大家可以参考,有错误希望帮忙指正,现在正处于编写阶段,一共将 ...
- (转)c语言_链表实例讲解(两个经典例子)
建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. #include <stdio.h>#include <stdlib.h> struct grade { ...
- Javascript模仿C语言的链表实现(增删改查),并且使用控制台输入输出
Js新手最近在研究Js数据结构,刚好看到链表实现这一块儿,觉得有些资料和自己理解的有冲突,于是借着自己以前一点点C语言的基础,用Javascript模仿了C的链表实现,并且用了process.stdi ...
- c语言_链表实例讲解(两个经典例子)
建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. demo1 // lianbiao.cpp : Defines the entry point for the console app ...
随机推荐
- hive(在大数据集合上的类SQL查询和表)学习
1.jdbc:mysql://localhost:3306/hive?createDatabaseIfNotExist=true&characterEncoding=UTF-8&use ...
- 10、Semantic-UI之图片的使用
10.1 图片的使用 定义有边框的图片样式 <img class="ui medium bordered image" src="../images/pic.png ...
- fiddler-实现https抓包
1. fiddler设置-fiddler options-https项进行设置,如下: 2. ie代理设置:连接-局域网设置 3. 下载fiddler根证书,ie浏览器上打开地址:http://1 ...
- 介绍自己以及github注册流程
我叫何季生,来自网络工程141,学号是1413042027,我喜欢看一些动漫和游戏,对于编程并不是很厉害希望今年能够有所突破. github注册流程:在刚开始注册github时,我用的是qq浏览器,却 ...
- 利用PhotoShop对大图像进行等分切片
图文介绍利用PhotoShop等分切图 1.调用切片工具,右键选择划分切片 2.指定水平划分.垂直划分的等分数量,点击确定 3.在文件菜单中选择存储为... 4.配置图像质量参数.点击存储.指定存储位 ...
- 利用html5 postMessage接口跨域设置iframe大小
<!doctype html> <html> <head> <title>Document A</title> <meta chars ...
- [Erlang14]怎样模拟节点互连后的各种失败情况?
情景: 当节点群互连时,会通过心跳包检查所连接节点是不是连接正常,这个心跳时间默认为60s,可以通过 net_kernel:set_net_ticktime(600). 来重设这个时间值,怎么测试? ...
- 线上 ELK 集群健康值 red 状态问题排查与解决
之前一直运行正常的数据分析平台,最近一段时间没有注意发现日志索引数据一直未生成,大概持续了n多天,当前状态: 单台机器, Elasticsearch(下面称ES)单节点(空集群),1000+shrad ...
- Tomcat源码(一):整体架构
由于tomcat的组件较多,处理流程比较复杂 ,这里是 由浅到深来解释tomcat的整体架构 1.首先应该大致了解下tomcat的 /conf/server.xml 配置文件:在tomcat启动的时 ...
- 24. 两两交换链表中的节点 leetcode
题目: 给定一个链表,两两交换其中相邻的节点,并返回交换后的链表. 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换. 示例: 给定 1->2->3->4, 你应该返回 ...