单向链表的建立,添加与删除

/*-------------------------包含头文件------------------------------------*/

#include<stdio.h>

#include<stdlib.h>

#include<malloc.h>

#include<string.h>

int count=0;

/*-------------------------结构体定义部分------------------------------*/

typedef struct Node

{

char name[10];

int score;

struct Node *next;

} ListNode;

/*----------------------------函数声明部分------------------------------*/

/*---------------------------函数实现部分-------------------------------*/

/*-----------------------------创建链表---------------------------------*/

/*在链表的末端插入新的节点,建立链表*/

ListNode *CreateList()

{

ListNode *head;//指向头结点指针

ListNode *p,*pre;

head=(ListNode *)malloc(sizeof(ListNode));//为头节点分配内存空间

head->next=NULL;//将头结点的指针域清空

pre=head;//先将头结点首地址赋给中间变量pre

while(1)

{

if((p=(ListNode *)malloc(sizeof(ListNode)))==NULL)

{

printf("内存空间不足!!!\n");

break;

}

count++;

printf("input name of the %d student(input \"q\" to quit):",count);//打印出第几个人的名字

//内存空间p指向新插入结点的首地址

scanf("%s",&p->name);//输入姓名

if(strcmp(p->name,"q")==0)

break;

printf("input score of the %d student:",count);

scanf("%d",&p->score);//输入分数

pre->next=p;//将p指向新结点插入链表也就是头结点指针域指向

//下个结点

//第一个结点就是p指向的,因为头结点内容为空

pre=p;//这个起着指向下一个结点的作用

pre->next=NULL;

}

return head;//返回这个链表的首地址

}

/*-------------------------输出链表-----------------------------------*/

void PrintList(ListNode *h)

{

ListNode *p;

p=h->next;

while(p)

{

printf("%s,%d",p->name,p->score);

p=p->next;

printf("\n");

}

}

/*----------------------插入链表结点--------------------------*/

/*--------------------------------------------------------------------

函数名称:InsertList(ListNode *h,int i,char name[],int e,int n)

函数功能:插入链表结点

入口参数: h: 头结点地址 i:插入到第几个结点 name:插入结点的姓名 e:插入结点的分数 n:链表中结点的个数除下头结点外的个数

出口参数:

--------------------------------------------------------------------*/

void InsertList(ListNode *h,int i,char name[],int e,int n)

{

ListNode *p,*q;  //先定义2个指向一个结点的指针

if(i<1||i>n+1)

printf("Error!!!\n");

else

{

int j=1;

p=h;//将指针p指向要链表的头结点

while(j<i)

{

p=p->next;

j++;

}

if((q=(ListNode *)malloc(sizeof(ListNode)))==NULL)/*为要插入的

结点分配内存空间*/

printf("内存空间不足!!!\n");

else

{

count++;

strcpy(q->name,name);//将名字拷到要插入的节点内

q->score=e;//将要插入的节点中分数赋值

q->next=p->next;/*这个是将新插入的结点指针域指向

上一个结点指针域指向的结点地址即为p->next*/

p->next=q;/*将要插入结点位置前面的结点指针域

指向现在插入的结点首地址*/

}

}

}

/*--------------------------------------------------------------------

函数名称:DeleteList(ListNode *h, int i, int n)

函数功能:删除链表结点

入口参数: h: 头结点地址 i:要删除的结点所在位置  n:链表中结点的个数除下头结点外的个数

出口参数:

--------------------------------------------------------------------*/

void DeleteList(ListNode *h, int i, int n)

{

ListNode *p,*q;//首先定义2个指向结点型结构体的指针

char name[10];

int score;

if(i<1||i>count+1)

printf("Error!!!\n");

else

{

int j=1;

p=h;//将指针指向链表的头结点首地址

while(j<i)

{

p=p->next;

j++;

}

q=p->next;/*q指向要删除的位置之前的那个结点指针域指向的

地址q指向的结点就是要删除的结点*/

p->next=q->next;/*这个就是将要删除的结点的前面那个结点

的指针域指向要删除的结点指针域中存放的下个结点的

首地址从而实现了删除第i个结点的作用*/

strcpy(name,q->name);

score=q->score;

free(q);//释放q指向的结点

printf("name:%s\tscore:%d has been deleted!!!\n",name,score);

}

}

/*--------------------------主函数-------------------------------*/

int main()

{

ListNode *h;//h指向结构体NODE

int i = 1, n, score;

char name [10];

while ( i )

{

/*输入提示信息*/

printf("1--建立新的链表\n");

printf("2--添加元素\n");

printf("3--删除元素\n");

printf("4--输出当前表中的元素\n");

printf("0--退出\n");

scanf("%d",&i);

switch(i)

{

case 1:

h=CreateList();/*创建链表*/

printf("list elements is : \n");

PrintList(h);

break;

case 2:

printf("input the position. of insert element:");

scanf("%d",&i);

printf("input name of the student:");

scanf("%s",name);

printf("input score of the student:");

scanf("%d",&score);

InsertList(h,i,name,score,count);

printf("list elements is:\n");

PrintList(h);

break;

case 3:

printf("input the position of delete element:");

scanf("%d",&i);

DeleteList(h,i,count);

printf("list elements in : \n");

PrintList(h);

break;

case 4:

printf("list element is : \n");

PrintList(h);

break;

case 0:

return;

break;

default:

printf("ERROR!Try again!\n");

}

}

return 0;

}

单向链表的建立,添加与删除

时间: 2024-10-13 02:42:36

单向链表的建立,添加与删除的相关文章

单向链表的元素查找和删除

整个过程以根节点为基础,先确定根节点的情况,再一次类推 1 package test02; 2 3 /* 4 * 单向链表的正宗实现 5 * */ 6 7 class Link{ 8 class Node{ 9 private String data; 10 private Node next; 11 public Node(String data){ 12 this.data = data; 13 } 14 public void addNode(Node newNode){ 15 if(th

单向链表的建立(2)

链表的建立可以使用尾插法,也可以使用头插法,头插法就是从头节点开始,向前扩展节点,最后生成带头节点的单向链表,使得内容与输入相反. 链表的定义与(1)中相同,这里只介绍链表的建立函数. 1 LNode *create(int n) 2 { 3 int m; 4 LNode *head=(LNode *)malloc(sizeof(LNode)); 5 LNode *tail=(LNode *)malloc(sizeof(LNode)); 6 LNode *p; 7 head->next=NULL

单链表节点的添加和删除

单链表的节点定义 struct ListNode { int m_nValue; ListNode* m_pNext; }; 在单链表的末尾添加结点 void AddToTail(LIstNode** pHead,int value) { ListNode* pNew = new ListNode(); pNew->m_nValue = value; pNew->m_pNext = NULL; if(*pHead == NULL) *pHead = pNew; else { ListNode*

链表的创建以及链表节点的添加和删除

单链表的创建过程有下面几步: 1 ) 定义链表的数据结构; 2 ) 创建一个空表; 3 ) 利用malloc ( )函数向系统申请分配一个节点; 4 ) 将新节点的指针成员赋值为空. 若是空表,将新节点连接到表头:若是非空表,将新节点接到表尾; 5 ) 推断一下是否有兴许节点要接入链表,若有转到3 ),否则结束; 单链表的输出过程有下面几步 1) 找到表头; 2) 若是非空表.输出节点的值成员,是空表则退出; 3 ) 跟踪链表的增长,即找到下一个节点的地址; 4) 转到2 ). 接下来来一步步实

单向链表的建立,插入,删除(复习一下)

#include <iostream> #include <cstdio> #include <cstdlib> using namespace std; typedef int datetype; typedef struct node { datetype date; struct node* next; }listnode,*linklist; linklist creatlist(int num)//创建链表 { int i; linklist tail=NUL

单向链表的建立与遍历

软件152笪世海 #include "stdio.h"#include <stdlib.h>#include <time.h> enum Status{OK,ERROR};typedef int ElemType; typedef struct LNode { ElemType data;///链表结点的元素,类型为int LNode *next;//指向下一结点指针}LNode,*LinkList; Status CreatLink(LinkList &

数据结构--单向链表

C语言中,我们在使用数组时,会需要对数组进行插入和删除的操作,这时就需要移动大量的数组元素,但在C语言中,数组属于静态内存分配,数组在定义时就必须指定数组的长度或者初始化.这样程序一旦运行,数组的长度就不能再改变,若想改变,就只能修改源代码.实际使用中数组元素的个数也不能超过数组元素的最大长度,否则就会发生下标越界的错误(这是新手在初学C语言时肯定会遇到的问题,相信老师也会反复强调!!!但这种问题肯定会遇到,找半天找不到错误在哪,怪我咯???).另外如果数组元素的使用低于最大长度,又会造成系统资

链表(四)——带表头的单向链表

1.带表头的单向链表 (1)不带表头的单向链表在实现插入和删除时必须区分头结点和其他节点的处理. (2)使用带表头的单向链表的好处:不用考虑头结点的单独处理. 表头节点:数据域没有值,指针域指向单向链表中数据域含值的第一个结点. 2.代表头的单向链表的基本操作 #include <stdio.h> #include <malloc.h> #define NULL 0 typedef struct node { int data; struct node *next; }ElemSN

「C语言」单链表/双向链表的建立/遍历/插入/删除

最近临近期末的C语言课程设计比平时练习作业一下难了不止一个档次,第一次接触到了C语言的框架开发,了解了View(界面层).Service(业务逻辑层).Persistence(持久化层)的分离和耦合,一种面向过程的MVC的感觉. 而这一切的基础就在于对链表的创建.删除.输出.写入文件.从文件读出...... 本篇文章在于巩固链表的基础知识(整理自<C语言程序设计教程--人民邮电出版社>第十章),只对链表的概念及增删改查作出探讨,欢迎指教. 一.链表结构和静态/动态链表 二.单链表的建立与遍历