链表的创建、测长、排序、插入、逆序的实现(C语言)
- #include <stdio.h>
- #define END_elem 0
- struct node
- {
- int date;
- struct node * next;
- };
- //链表创建
- node * creat()
- {
- int x;
- node *head,*last,*p;
- head=new node();
- last=head;
- scanf("%d",&x);
- while(x!=END_elem)
- {
- p=new node();
- p->date=x;
- last->next=p;
- last=p;
- scanf("%d",&x);
- }
- head=head->next;
- last->next=NULL;
- return head;
- }
- //单链表测长
- int lenght(node *head)
- {
- int n=0;
- node *p=head;
- while(p!=NULL)
- {
- p=p->next;
- n++;
- }
- return n;
- }
- //链表排序
- node *sort(node *head,int n)
- {
- int temp;
- node *p;
- if(head==NULL||head->next==NULL)
- return head;
- for(int i=0;i<n-1;i++)
- {
- p=head;
- for(int j=0;j<n-1-i;j++)
- {
- if(p->date>p->next->date)
- {
- temp=p->date;
- p->date=p->next->date;
- p->next->date=temp;
- }
- p=p->next;
- }
- }
- return head;
- }
- //链表插入
- node * insert(node *head,int num)
- {
- node *p,*q,*t;
- p=head;
- t=new node();
- t->date=num;
- while(num>p->date&&p->next!=NULL)
- {
- q=p;
- p=p->next;
- }
- if(num<=p->date)
- {
- if(p==head)
- {
- t->next=p;
- head=t;
- }
- else
- {
- t->next=p;
- q->next=t;
- }
- }
- else//把插入点定在表尾
- {
- p->next=t;
- t->next=NULL;
- }
- return head;
- }
- //链表输出
- void print(node *head)
- {
- struct node *p=head;
- while(p!=NULL)
- {
- printf("%d\n",p->date);
- p=p->next;
- }
- }
- //链表删除
- node *del(node *head,int num)
- {
- node *p,*q;
- p=head;
- while(num!=p->date&&p->next!=NULL)
- {
- q=p;
- p=p->next;
- }
- if(p->date==num)
- {
- if(p==head)
- {
- head=p->next;
- delete p;
- }
- else
- {
- q->next=p->next;
- delete p;
- }
- }
- else
- printf("Didn't Fond The Num!");
- return head;
- }
- //链表逆序
- node *reverse(node *head)
- {
- node *p1,*p2,*p3;
- p1=head;
- p2=head->next;
- while(p2)
- {
- p3=p2->next;
- p2->next=p1;
- p1=p2;
- p2=p3;
- }
- head->next=NULL;
- head=p1;
- return head;
- }
- void main()
- {
- struct node *head;
- int n,m;
- printf("链表创建,输入数字:\n");
- head=creat();
- print(head);
- n=lenght(head);
- printf("链表的长度为 %d\n",n);
- printf("链表排序:\n");
- head=sort(head,n);
- print(head);
- printf("输入要插入链表的数:\n");
- scanf("%d",&m);
- printf("插入后的链表:\n");
- head=insert(head,m);
- print(head);
- printf("链表逆序:\n");
- head=reverse(head);
- print(head);
- }
链表的创建、测长、排序、插入、逆序的实现(C语言)的更多相关文章
- 将单链表的每K个节点之间逆序
[说明]: 本文是左程云老师所著的<程序员面试代码指南>第二章中“将单链表的每K个节点之间逆序”这一题目的C++复现. 本文只包含问题描述.C++代码的实现以及简单的思路,不包含解析说明, ...
- 【链表问题】打卡9:将单链表的每K个节点之间逆序
前言 以专题的形式更新刷题贴,欢迎跟我一起学习刷题,相信我,你的坚持,绝对会有意想不到的收获.每道题会提供简单的解答,如果你有更优雅的做法,欢迎提供指点,谢谢. 注:如果代码排版出现了问题麻烦通知我下 ...
- 栈和队列----将单链表的每K个节点之间逆序
将单链表的每K个节点之间逆序 给定一个单链表的头节点head,实现一个调整链表的函数,使得每K 个节点之间逆序,如果最后剩下不够K 个节点,则不调整最后几个. 例如: 链表:1—>2—>3 ...
- 左神算法书籍《程序员代码面试指南》——2_11将单链表的每K个节点之间逆序
[题目]给定一个单链表的头节点head,实现一个调整单链表的函数,使得每K个节点之间逆序,如果最后不够K个节点一组,则不调整最后几个节点.例如:链表:1->2->3->4->5 ...
- [算法] 将单链表的每K个节点之间逆序
题目 给定一个单链表的头结点,实现一个调整单链表的函数,使得每K个节点之间逆序,如果最后不够K个节点一组,则不调整最后几个节点. 解答 使用栈结构 import java.util.Stack; pu ...
- 算法总结之 将单链表的每K个节点之间逆序
给定一个单链表的表头节点head,实现一个调整单链表的函数,是的每k个节点之间逆序,如果最后不够k个节点一组,则不调整最后几个节点 思路: 如果k的值小于2,不调整.k<1 没有意义,k==1代 ...
- [程序员代码面试指南]链表问题-将单链表的每k个节点之间逆序
题目描述 给定一个单链表的表头节点head,实现一个调整单链表的函数,是的每k个节点之间逆序,如果最后不够k个节点一组,则不调整最后几个节点. 题解 内部函数reverse实现链表beg到end的翻转 ...
- 使用OC实现单链表:创建、删除、插入、查询、遍历、反转、合并、判断相交、求成环入口
一.概念 链表和数组都是一种线性结构,数组有序存储的,链表是无序存储的. 数组中的每一个元素地址是递增或者递减的关系,链表的每一个节点的地址没有此规律,它们是通过指针的指向连接起来. 链表种类:单链表 ...
- Linux C++ 单链表添加,删除,输出,逆序操作
/*单链表操作*/#include <iostream>using namespace std; class Node{ public: Node(){ next=0; } Node(in ...
- 链表逆序(JAVA实现)
题目:将一个有链表头的单向单链表逆序 分析: 链表为空或只有一个元素直接返回: 设置两个前后相邻的指针p,q,使得p指向的节点为q指向的节点的后继: 重复步骤2,直到q为空: 调整链表头和链表尾: 图 ...
随机推荐
- android startActivityForResult的用法
有时候我们需要把A activity提交数据给B activity处理,然后把结果返回给A 这种方式在很多种情况需要用到,比如我应用的程序需要有拍照上传的功能. 一种解决方案是 我的应用程序 〉调 ...
- Progressive JPEG
和Baseline一遍扫描不同,Progressive JPEG文件包含多次扫描,这些扫描顺寻的存储在JPEG文件中.打开文件过程中,会先显示整个图片的模糊轮廓,随着扫描次数的增加,图片变得越来越清晰 ...
- VS环境下搭建自己NuGet服务器
一.NuGet服务端的搭建 环境:.NET 4.5 + VS2015 + NuGet.Server 2.10.1 1.建一个空的Web项目,取名叫NuGetServer 2.通过NuGet安装NuGe ...
- Is an MTD device a block device or a char device?
转:http://www.linux-mtd.infradead.org/faq/general.html#L_mtd_what Note, you can find Ukranian transla ...
- .NET 托管堆和垃圾回收
托管堆基础 简述:每个程序都要使用这样或那样的资源,包括文件.内存缓冲区.屏幕空间.网络连接.....事实上,在面向对象的环境中,每个类型都代表可供程序使用的一种资源.要使用这些资源,必须为代表 ...
- solr 竞价排行
在理想的情况下,搜索引擎只返回与用户查询相关的文档.而在现实的查询中,编辑(没发现更合适的表达)通常需要指定特定文档在搜索结果中的特定位置.这样做有很多原因.或许 “置顶” 的文档就是最好的查询结果. ...
- VMware系统运维(二十)部署虚拟化桌面Horzion View 5.2 HTML Access进行连接测试
1.通过浏览器打开Horzion View登录界面,https://conntionserver.testad.local,点击"VMware Horzion View HTML Acces ...
- js 数组中随机出来N组
var word = []; while (word.length < 7) { var tmp = data[parseInt(Math.random() * data.length)]; v ...
- [转]使用 HTML5 索引型数据库的待办事项简要列表
本文转自:http://www.html5rocks.com/zh/tutorials/indexeddb/todo/ <!DOCTYPE html><html> <h ...
- 正则转nfa:bug出现。
本人写的一个正则到nfa的bug 刚写完前面的那篇,自己用脑子过了一下,发现了一个bug.具体情况如下. 这个bug的产生条件是多次调用假名的时候,每次调用都会修改假名的nfa图.直接这么说不好理解, ...