链表的插入、删除、排序的程序

#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
typedef struct node
{int data;struct node * pNext;
}*pNode,Node;
//#define bool int;	//#define的意思是单纯的替换,与别名没有关系,而且C语言中没有bool数据类型
typedef int bool;	//typedef的意思就是别名,或者是声明结构体数据类型的变量,int 用bool来替换
#define true 0
#define false 1
pNode create_list();
void traverse_list(const pNode);
bool is_empty(const pNode);
int length_list(const pNode);
bool insert_list(pNode, int, int);
bool delete_list(pNode, int);
void sort1_list(const pNode);
void sort2_list(const pNode);
int find_list(const pNode, int);
//void sort3_list(const pNode, int left, int right);
int main(void)
{pNode pHead=NULL;pHead=create_list();if(is_empty(pHead)){puts("链表不为空!");}elseputs("链表为空!");printf("链表的长度为:%d\n",length_list(pHead));puts("-----------------------------------链表值为--------------------------------");traverse_list(pHead);puts("-----------------------------------冒泡排序--------------------------------");sort1_list(pHead);traverse_list(pHead);puts("-----------------------------------普通排序--------------------------------");sort2_list(pHead);traverse_list(pHead);//puts("------------------------------------快速排序-----------------------------");//sort3_list(pHead,1,5);//traverse_list(pHead);puts("-----------------------------------插入链表--------------------------------");insert_list(pHead, 5, 77);traverse_list(pHead);puts("-----------------------------------删除链表--------------------------------");delete_list(pHead,3);traverse_list(pHead);puts("-----------------------------------查找链表---------------------------------");find_list(pHead,49);return 0;
}
pNode create_list()
{int len,val,i;	//特别注意:C语言中,变量的定义必须放在前面,否则编译无法识别,会报错。pNode pTail;pNode pHead=(pNode)malloc(sizeof(Node));if(pHead==NULL){printf("动态内存分配失败!\n");exit(-1);}pTail=pHead;pTail->pNext=NULL;printf("请输入有效节点个数:len=");scanf("%d",&len);for(i=0;i<len;++i){pNode pNew=(pNode)malloc(sizeof(Node));if(pNew==NULL){printf("动态内存分配失败!");exit(-1);}printf("请输入数第%d个据域的值val=",i+1);scanf("%d",&val);pNew->data=val;pTail->pNext=pNew;pTail=pNew;pTail->pNext=NULL;}return pHead;
}
void traverse_list(const pNode pHead){pNode p=pHead->pNext;while(p!=NULL){printf("%d\t",p->data);p=p->pNext;}putchar('\n');return;
}
bool is_empty(const pNode pHead)
{if(pHead->pNext==NULL)return true;elsereturn false;
}
int length_list(const pNode pHead)
{int count=0;pNode p=pHead;while(p!=NULL){count++;p=p->pNext;}return count;
}
bool insert_list(pNode pHead, int pos, int val)	//位置从有效节点1开始
{int count=length_list(pHead);int i=1;pNode p=pHead;pNode q=(pNode)malloc(sizeof(Node));if(q==NULL){puts("内存分配失败!");exit(-1);}q->data=val;if(pos<2 || pos>count+1){puts("链表当中不存在该位置!");return false;}while(i<pos-1){++i;p=p->pNext;}q->pNext=p->pNext;p->pNext=q;return true;
}
bool delete_list(pNode pHead, int pos)
{int count=length_list(pHead);int i=1;pNode p=pHead->pNext;pNode q;if(pos<2 || pos>count){puts("链表当中不存在该位置!");return false;}while(i<pos-1){++i;p=p->pNext;}printf("删除的值是:%d\n",p->pNext->data);q=p->pNext;p->pNext=q->pNext;free(q);//p->pNext=p->pNext->pNext;//free(p->pNext);//不能这么释放,这是错误的return true;
}
//冒泡排序
void sort1_list(const pNode pHead)
{int count=length_list(pHead);pNode p;int i,j;/*这是定义变量,不叫逗号表达式。需要是表达式才行。逗号表达式只取最后的那个表达式的值作为整个表达式的值,但是前边的表达式也要运行,左结合性,从左往右运行的。这个链表的for循环一定要用i,j;否则上限没法表示。*/for(i=1,p=pHead->pNext;i<count-1;++i,p=p->pNext)for(j=1,p=pHead->pNext;j<count-i;++j,p=p->pNext){if(p->data > p->pNext->data){int temp;temp=p->data;p->data=p->pNext->data;p->pNext->data=temp;}}return;
}
//普通排序,注意第三方的使用非常重要
void sort2_list(const pNode pHead)
{int count=length_list(pHead);pNode p,q;int i,j;for(i=1,p=pHead->pNext;i<count-1;++i,p=p->pNext)//第一个for循环表示比较多少次for(j=i+1,q=p->pNext;j<count;++j,q=q->pNext)//第二个for循环表示和哪个对象比较{if(p->data > q->data){int temp;temp=p->data;p->data=q->data;q->data=temp;}}return;
}
int find_list(const pNode pHead, int val)
{pNode p=pHead->pNext;int count=length_list(pHead);int flag=1,flag2=0;while(p !=NULL ){if(p->data==val){printf("你要查找的数的位置:%d\n",flag);flag2++;}p=p->pNext;++flag;}if(flag2==0)puts("链表中没有查找的值!");return flag;}
//快速排序
/*
void sort3_list(const pNode pHead, int left, int right)
{pNode p=pHead->pNext;pNode q=pHead->pNext;pNode r=NULL;int i=left;int j=right;int key=p->data;int count=length_list(pHead);while(q != NULL)q=q->pNext;if(i>=j)exit(-1);while(i<j){//for(i=left,p=pHead->pNext;i<j,q->data<key;--j)while(i<j && q->data<key ){--j;r->pNext=q;q=r;r=NULL;break;}p->data=q->data;//a[i]=a[j];while(i<j && p->data>key ){++i;p=p->pNext;break;}q->data=p->data;}p->data=key;sort3_list(pHead, left, i-1);sort3_list(pHead, j+1, right);
}
*/

  

转载于:https://www.cnblogs.com/fengkui/p/6117932.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/469812.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux-2.6.32在mini2440开发板上移植(16)之LED 驱动程序移植

LED 驱动程序移植 编者&#xff1b;对于led的驱动程序&#xff0c;很多文章都有详细的介绍&#xff0c;我的博客里面有一篇专门详解这个的。需要看的&#xff0c;可以找下。led灯的驱动其实就代表了I/O口的驱动。在linux系统下&#xff0c;操作一个I/O口&#xff0c;可以说实在…

单变量批量梯度下降算法与单变量随机梯度下降算法

2.3 代价函数的直观理解I 让我们通过一些例子来获取一些直观的感受&#xff0c;看看代价函数到底是在干什么。 2.4 代价函数的直观理解II 代价函数的样子类似于等高线图&#xff0c;则可以看出在三维空间中存在一个J(θ0,θ1)使得最小的点。 通过这些图形&#xff0c;我希望你…

一台计算机连入计算机网络后通过该计算机,一台计算机连入计算机网络后,该计算机( )。...

摘要&#xff1a;计算机连当碰撞已不可避免时,船舶应根据良好船艺的要求采取最有效的行动以减小碰撞的损失,下列说法正确的是()。①应避免两船首相撞;②应避免一船船首撞入他船机舱附近或船中;③应尽量使两船相撞前相对速度达到最大;④应尽量使两船相撞前相对速度达到最小。算机…

LCD驱动移植(一)

一、种类 LCD的种类比较多,有以下四种,不过现在我们用的大多是TFT液晶显示屏 1、TN型显示器 2、STN型彩色显示器 3、DSTN型显示器 4、TFT显示器 二、LCD参数 (1)尺寸

python调用其他程序或脚本方法(转)

python运行&#xff08;调用&#xff09;其他程序或脚本 在Python中可以方便地使用os模块运行其他的脚本或者程序&#xff0c;这样就可以在脚本中直接使用其他脚本&#xff0c;或者程序提供的功能&#xff0c;而不必再次编写实现该功能的代码。为了更好地控制运行的进程&#x…

反向传播+代码实现

ywx的反向传播代码实现 import torch x_data [1.0, 2.0, 3.0] y_data [2.0, 4.0, 6.0]#w是Tensor(张量类型)&#xff0c;Tensor中包含data和grad&#xff0c;data和grad也是Tensor。 # grad初始为None&#xff0c;调用l.backward()方法后w.grad为Tensor&#xff0c; # 故更…

考研专业课计算机网络调剂,计算机网络信息中心2019年硕士研究生接收调剂信息公告...

一、外单位考生调剂1.接收调剂要求报考学科门类 政治理论 外国语 业务课一 业务课二 总分工学(08) 同国家复试分数线基本要求 325工程(0852) 同国家复试分数线基本要求 325中心调剂指标预计在4人左右&#xff0c;均为计算机技术专业。2.调剂流程1、3月26日14&#xff1a;00至3月…

linux目录树(书本上看到)

LINUX的目录树 /bin bin 是binary 的缩写。这个目录是对UNIX 系统习惯的沿袭,存放着使用者最经常使用的命令。例如:cp,ls,cat。 /boot 这里存放的是启动LINUX 时使用的一些核心文件。 /dev dev 是device(设备)的缩写。这个目录下是所有LINUX 的外部设备,其功能类似DOS 下的.…

Collection中Set集合在应用中常见的方法和注意点

Set集合 &#xff1a; 元素无序的&#xff0c;元素不允许重复。 ---->HashSet : 存值方式使用哈希表来存值的。 原理 &#xff1a; 如果HashSet中存放对象 ,首先会调用对象的hashCode方法获取到哈希值&#xff0c;通过哈希值做移为等运算&#xff…

【Pytorch神经网络实战案例】04 使用Pytorch实现线性回归

import torchx_data torch.tensor([[1.0],[2.0],[3.0]]) y_datatorch.tensor([[2.0],[4.0],[6.0]])#重点在于构造计算图 pytorch会自动计算梯度 #Zwxb 就是一个线性单元class LinearModel(torch.nn.Module):#Module的对象会自动实现backword()的过程#构造函数def __init__(self…

html 网页制作标签,html网页制作标签最全版.doc

html网页制作标签最全版MetaName(页面描述信息)keywords。关键字&#xff0c;格式&#xff1a;description。描述&#xff0c;格式&#xff1a;author。 作者&#xff0c;格式&#xff1a;generator。编写工具&#xff0c;格式&#xff1a;robots。 机器人&#xff0c;格式&…

menu菜单

[1]添加菜单方式 通过一个布局 在res下 meun目录下创建一个布局 <menu xmlns:android"http://schemas.android.com/apk/res/android" ><itemandroid:id"id/action_settings1"android:orderInCategory"10"android:title"hahah"…

计算机网络阅读报告,计算机网络实验二报告

计算机网络实验二报告 (5页)本资源提供全文预览&#xff0c;点击全文预览即可全文预览,如果喜欢文档就下载吧&#xff0c;查找使用更方便哦&#xff01;11.90 积分&#xfeff;计算机网络实验报告课程_ 计算机网络 _ 实验名称 TCP/IP协议分析与验证 姓 名 实 验 日 期&#xff…

LCD驱动移植(二)

LCD驱动的话会在MINI2440里是向Plaform注册的一个驱动 Plaform的话可以在网上查查这方面的资料&#xff0c;主要要注意这两个函数&#xff0c;如下&#xff1a; (1)platform_device_register()注册平台XX设备。 (2)platform_driver_register()注册平台XX驱动。 下面贴出LCD驱…

使用Pytorch处理多维特征的输入

下图这个预测一个人在一年之后得糖尿病的概率的例子&#xff0c;这个时候我们的输入将会有很多的指标。你可以把它看成是我们体检的各种值。最后一排的外代表了他是否会得糖尿病。 那么多维的特征输入应该怎么办呢&#xff1f;我们就需要把每一个特征x付以相应的权重。在进行逻…

dubbo学习 三 dubbox概述

当当网根据自身的需求&#xff0c;对dubbo进行了扩展就叫成了dubbox。具体的使用方法可以参照官网各种例子&#xff1a;http://dangdangdotcom.github.io/dubbox/ 支持rest风格远程调用 之前了解过restful服务具体是什么&#xff0c;resteasy也了解过&#xff0c;所以看到就可以…

非大学生学计算机,浅谈非计算机专业大学生的计算机教学

第 卷 年 月黑 龙 江 科 学浅谈非计 算机 专业 大学生的计算机教 学曾 宇(辽源职业技术学院医药分院 &#xff0c;吉林 辽源 )摘 要 &#xff1a;为了提高大学生计算机应用能力 &#xff0c;适应社会及用人单位的需求 &#xff0c;对 非计算机专业大学生的计 算机教学提 出了更…

linux platform 驱动模型分析

一. 概述platform设备和驱动与linux设备模型密切相关。platform在linux设备模型中&#xff0c;其实就是一种虚拟总线没有对应的硬件结构。它的主要作用就是管理系统的外设资源&#xff0c;比如io内存,中断信号线。现在大多数处理器芯片都是soc&#xff0c;如s3c2440&#xff0c…

使用Pytorch完成多分类问题

多分类问题在最后的输出层采用的Softmax Layer&#xff0c;其具有两个特点&#xff1a;1.每个输出的值都是在(0,1)&#xff1b;2.所有值加起来和为1. 假设是最后线性层的输出&#xff0c;则对应的Softmax function为&#xff1a; 输出经过sigmoid运算即可是西安输出的分类概率…

PyTorch的nn.Linear()详解

1. nn.Linear() nn.Linear()&#xff1a;用于设置网络中的全连接层&#xff0c;需要注意的是全连接层的输入与输出都是二维张量 一般形状为[batch_size, size]&#xff0c;不同于卷积层要求输入输出是四维张量。其用法与形参说明如下&#xff1a; in_features指的是输入的二维…