数据结构带头结点单向不循环链表(C语言版)

main.c,负责测试

#define  _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include<stdlib.h>
#include "linklist.h"
int main()
{LNode* list=NULL;int i = 0,err =0;datatype a = 40,return_value=0;datatype arr[] = { 20,10,90,100,50,40,20,60,70,80 };//创建链表list = create_list();if (list == NULL){fprintf(stderr, "create_list()failed\n");return -1;}//链表中插入数据,按照从小到大的顺序插入for (i = 0; i < sizeof(arr)/sizeof(*arr); i++){//插入失败,返回-2list_order_insert(list,&arr[i]);}//打印链表list_display(list);//按照元素删除链表中data域为40的节点//delete_list(list, &a);//list_display(list);//按位置删除链表中下标为3的节点,注意链表中有效节点的下标从0开始,retun_value接收返回值/*delete_list_at(list,3,&return_value);printf("删除节点的数据为%d\n", return_value);list_display(list);*/destroy_list(list);
}

linklist.c 负责具体的代码实现

#include<stdio.h>
#include<stdlib.h>
#include "linklist.h"
LNode* create_list()
{LNode* ps = NULL;ps=(LNode*)malloc(sizeof(LNode));if (ps == NULL){return -1;}	else {ps->next = NULL;return ps;}}//按位置插入节点
int list_insert_at(LNode *ps, int i, datatype* data)
{//单向链表带头结点,第一个有效节点的下标为0int j = 0;LNode* node = ps;LNode* newnode = NULL;if (i < 0){return -1;}//找到第i-1个有效节点while((j < i)&&(node !=NULL)){node = node->next;j++;}//第i-1个有效节点存在,生成新节点if (node){newnode =(LNode*)malloc(sizeof(LNode));if (newnode == NULL){return -2;}newnode->data = *data;newnode->next = node->next;node->next = newnode;return 0;}else {return -3;}}//按从小到大的顺序插入元素
int list_order_insert(LNode* ps,datatype *data)
{LNode* prenode = ps,*curnode=ps->next,*newnode;while ((curnode != NULL)&&(curnode->data < *data)){prenode = curnode;curnode = curnode->next;}//生成新节点newnode = (LNode*)malloc(sizeof(LNode));if (newnode == NULL){return -1;}newnode->data = *data;newnode->next=prenode->next;prenode->next = newnode;return 0;
}
int list_display(LNode* ps)
{int i = 0;if (list_isempty(ps)){return -1;}printf("链表中的元素依次为:\n");//找到链表中第一个有效节点ps = ps->next;while (ps){printf("下标:%d\t数据:%d\n",i, ps->data);ps = ps->next;i++;}return 0;
}int delete_list_at(LNode *ps, int i,datatype *data)
{LNode *p = ps,*q=NULL;int j = 0;if (i < 0){return -1;}//找到第i-1个节点while((p!=NULL) &&(j < i)){p = p->next;j++;}if (p == NULL){return -2;}else{q = p->next;p->next = q->next;*data = q->data;free(q);q = NULL;return 0;}
}int delete_list(LNode *ps, datatype *data)
{LNode *prenode = ps, *curnode = ps->next;while ((curnode != NULL)&&(curnode->data != *data)){prenode = curnode;curnode = curnode->next;		}if (curnode == NULL){return -1;}else {prenode->next = curnode->next;free(curnode);curnode = NULL;return 0;}
}int list_isempty(LNode* ps)
{if (ps->next){return 0;}else{return 1;}
}int destroy_list(LNode* ps)
{LNode* newnode, *node = ps->next;//先销毁有效节点,最后销毁头结点while (node){newnode = node->next;free(node);node = NULL;node = newnode;}//销毁头结点free(ps);ps = NULL;return 0;
}

linklist.h(头文件,函数声明等)

#ifndef LINKLIST_H__
#define LINKLIST_H__
typedef int datatype;
typedef struct LNode
{datatype data;struct LNode *next;
}LNode;
LNode* create_list();
//按从小到大的顺序插入元素
int list_order_insert(LNode* ps, datatype *data);
//任意位置插入节点
int list_insert_at(LNode *ps, int i,datatype* data);
//按元素删除链表中的节点
int delete_list(LNode *ps, datatype *data);
//按位置删除链表中的节点,data接收返回值
int delete_list_at(LNode *ps, int i,datatype* data);
//打印链表中的数据
int list_display(LNode* ps);
//判断链表是否为空
int list_isempty(LNode* ps);
//销毁链表
int destroy_list(LNode* ps);
#endif

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

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

相关文章

Django设置TIME_ZONE和LANGUAGE_CODE为中国区域

Django默认的timezone是 TIME_ZONE America/Chicago LANGUAGE_CODE en-us 设置为中国区域&#xff1a; TIME_ZONE Asia/Shanghai LANGUAGE_CODE zh-cn 另外你可以根据情况设置 \Lib\site-packages\django\conf\global_settings.py 里面的时区转载于:https://www.cnblogs.co…

每天10分钟用python学数据分析_用Python做数据分析,Numpy,Pandas,matp

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼用Python做数据分析&#xff0c;Numpy&#xff0c;Pandas&#xff0c;matplotlib是怎么也绕不开的三个包&#xff0c;我最开始学习pandas是看的《利用Python进行数据分析》&#xff0c;看了好几遍&#xff0c;不是从头到尾看了好几…

使用Shell脚本查询服务器硬件信息

1、为了方便查询服务器的硬件信息&#xff0c;将需要查询的内容整理成Shell脚本&#xff0c;输出自己想要的格式。其实就是通过dmidecode命令输出&#xff0c;然后通过sed&#xff0c;awk&#xff0c;cut命令的处理。2、此脚步适用于HP DL系列的服务器&#xff0c;Dell PowerEd…

SQL Server 数据库维护脚本合集[005]-删除数据库所有用户表

--*****************************************************************************-- 作 者: qwu;-- 用 途: 删除数据库所有用户表;-- 版 本: v1.0-- 创建日期: 2011-3-23;-- 用 法: 设置use [数据库名],-- 注 意: !!!!!!!!慎用!!!!!!!!!;-- 修改历史: …

数据结构无头结点单向不循环链表(C语言版)

main.c(负责测试&#xff09; #include <stdlib.h> #include <stdio.h> #include <time.h> #include "nohead.h" int main() {LNode *list NULL;struct score_st data[10],mydata,data1;int i 0;srand((unsigned)time(NULL));//初始化数组for (…

ad network

全称&#xff1a;Advertising network。即“在线广告联盟”。一种介于想出售广告空间的网站与想在网站上刊登广告的广告主之间的平台。比较知名的公司有Google的AdSense、好耶、仁合传媒、传漾Adsame以及ValueClick等 Ad Network的本质真相是什么? 随视传媒COO薛晨女士在11月1…

python123查找指定字符输入m_大数据应用人才培养系列教材 Python语言 刘 鹏 张 燕 总主编 李肖俊 主编 刘 河 钟 涛 副主编....

Presentation on theme: "大数据应用人才培养系列教材 Python语言 刘 鹏 张 燕 总主编 李肖俊 主编 刘 河 钟 涛 副主编."— Presentation transcript:大数据应用人才培养系列教材 Python语言 刘 鹏 张 燕 总主编 李肖俊 主编 刘 河 钟 涛 副主编第五章 字符串与正则…

C#生成带Logo二维码

1.下载ThoughtWorks.QRCode引用并添加在工程中 2.在实现类QRCodeEncoderDemo中引入Dll&#xff0c;添加方法 using System;using System.Collections.Generic;using System.Drawing;using System.Drawing.Drawing2D;using System.Linq;using System.Web;using ThoughtWorks.QRC…

【原】基础篇:第一篇,本节主要向大家介绍Ext的最基础的话题

http://www.cnblogs.com/mogen_yin/archive/2009/04/30/1447236.html ExtJS是一个Ajax框架&#xff0c;是一个用javascript写的&#xff0c;用于在客户端创建丰富多彩的web应用程序界面。ExtJS可以用来开发RIA也即富客户端的AJAX应用 ExtJS是一个用javascript写的&#xff0c;主…

linux_base-f10-10_7 linuxulator is not (kld)loaded

# cd linux_base-f10/# make install clean> linux_base-f10-10_7 linuxulator is not (kld)loaded.*** Error code 1 解决办法&#xff1a;kldload linux 再重新执行make install clean命令即可。转载于:https://www.cnblogs.com/seasonsstory/p/3148870.html

margin的缩写

margin:0px;//页面内容距离浏览器边框的距离均为0px&#xff1b; margin:0px 5px;网页内容距离浏览器边框上下0px。左右5px margin&#xff1a;0px 10px 5px&#xff1b;//上0 &#xff0c;下10&#xff0c;左右5px margin:0px 1px 2px 3px;//上 右 下 左 0 1 2 3px; 其他的类…

前后端分离的项目部署到tomcat_如何在开发时部署和运行前后端分离的JavaWeb项目...

在开发中大型的JavaEE项目时&#xff0c;前后端分离的框架逐渐成为业界的主流&#xff0c;传统的单机部署前后端在同一个项目中的工程项目越来越少。这类JavaWeb项目的后端通常都采用微服务的架构&#xff0c;后端会被分解为诸多个小项目&#xff0c;然后使用dubbozookeeper或者…

51单片机实现三位十进制数加减乘除运算

51单片机实现三位十进制数加减乘除运算 一.题目 51单片机IO接口作业 请将附件给出的Proteus图用51单片机完成一个计算器功能。 1、显示采用动态分时8位共阳数码管输出。 2、采用4*4矩阵键盘输入&#xff0c;键盘上已经标识对应键。 3、完成三位十进制数的加、减、乘、除运…

未能加载文件或程序集“Microsoft.Office.Interop.Owc11, Version=11.0.0.0, ...”或它的某一个依赖项~[解决方案]...

配置错误 说明: 在处理向该请求提供服务所需的配置文件时出错。请检查下面的特定错误详细信息并适当地修改配置文件。 分析器错误信息: 未能加载文件或程序集“Microsoft.Office.Interop.Owc11, Version11.0.0.0, Cultureneutral, PublicKeyToken71e9bce111e9429c”或它的某一个…

方法javaJVM学习笔记-内存处理

本文是一篇关于方法java的帖子 大多数JVM将内存区域分离为Method Area&#xff08;Non-Heap&#xff09;&#xff0c;Heap&#xff0c;Program Counter Register&#xff0c;Java Method Statck&#xff0c;Native Method Stack和Direct Memomry&#xff08;备注&#xff1a;Di…

IPSEC ***两个阶段的协商过程

IPSEC 两个阶段的协商过程 第一阶段 有主模式和积极模式2种 注意!!!只有remote ***和Easy ***是积极模式的,其他都是用主模式来协商的 让IKE对等体彼此验证对方并确定会话密钥,这个阶段用DH进行密钥交换,创建完IKE SA后,所有后续的协商都将通过加密和完整性检查来保护 phase 1帮…

数据结构单向不循环链表实现多项式合并

多项式合并 思路 多项式合并 P1 5 2x 8x ^8 3x^16 P2 6x 16x^6 - 8x^8 P P1 P2 5 8x 16x^6 3x^16 使用带头结点的单向不循环链表 每个节点分为三个部分&#xff0c;系数项&#xff0c;指数项&#xff0c;指针域 结构体表示为 struct node_st {int exponent;int …

解决Warning: Cannot modify header information – headers already sent by

Warning: Cannot modify header information – headers already sent by….这类语句&#xff0c;造成这个原因是因为setcookie语句的问题。 上网找了半天&#xff0c;有人说要在文件开头写上ob_start(); output_buffering 改成4096 也失败失败。 后来打开 php.ini 然后把 outp…

下 终端_Linux/UNIX 下终端复用利器 tmux

tmux 是一个终端复用器(terminal multiplexer)。简介tmux 是一个终端复用器类自由软件&#xff0c;功能类似 GNU Screen&#xff0c;但使用 BSD 许可发布。用户可以通过 tmux 在一个终端内管理多个分离的会话&#xff0c;窗口及面板&#xff0c;对于同时使用多个命令行&#xf…

约瑟夫环(杀人游戏)

问题描述&#xff1a; 刚学数据结构的时候&#xff0c;我们可能用链表的方法去模拟这个过程&#xff0c;N个人看作是N个链表节点&#xff0c;节点1指向节点2&#xff0c;节点2指向节点3&#xff0c;……&#xff0c;节点N - 1指向节点N&#xff0c;节点N指向节点1&#xff0c;这…