C语言的单链表是常用的数据结构之一,本文总结了单链表的常见操作,实例如下:
?| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 |
#include<stdio.h>
#include<stdlib.h>
//定义单链表结构体
typedef int ElemType;
typedef struct Node
{
ElemType data;
struct Node *next;
}LNode,*LinkList;
//创建单链表
void Build(LinkList L)
{
int n;
LinkList p,q;
p=L;
printf("请输入n和n个元素:\n");
scanf("%d",&n);
while(n--)
{
q=(LinkList)malloc(sizeof(LNode));
scanf("%d",&q->data);
q->next = NULL;
p->next=q;
p=q;
}
}
//求单链表的长度
void LinkLength(LinkList L)
{
int num = 0;
LinkList p;
p=L->next;
while(p)
{
num++;
printf("%3d",p->data);
p=p->next;
}
printf("长度为:%d",num);
}
//查找前驱结点
void Find(LinkList L,int x)
{
LinkList p,q;
p=L;
while(p->next &&p->next->data!=x)
p=p->next;
if(p->next)
printf("%d的前驱结点为%d",x,p->data);
else
printf("没有找到");
}
//删除结点值为x的元素
void Delete(LinkList L,int x)
{
LinkList p,q;
p=L;
while(p->next && p->next->data!=x)
p=p->next;
if(p->next)
{
q=p->next;
p->next=q->next;
free(q);
}
printf("删除成功!!");
}
//将表中的元素逆置
void Reverse(LinkList L)
{
LinkList p,q;
p=q=L->next;
L->next=NULL;
while(p)
{
q=q->next;
p->next=L->next;
L->next=p;
p=q;
}
printf("逆置成功!!");
}
//对单链表排序
void sort(LinkList L)
{
LinkList p,q;
int temp;
p=L;
for(p=L;p->next!=NULL;p=p->next)
{
for(q=p->next;q!=NULL;q=q->next)
if(p->data>q->data)
{
temp=p->data;
p->data=q->data;
q->data=temp;
}
}
printf("排序成功!");
}
//删除相同元素
void Deletesameelem(LinkList L)
{
LinkList p,q,s;
p=L;
q=L->next;
while(q->next)
{
if(q->data ==q->next->data)
{
p->next=q->next;
s=q;
q=q->next;
free(s);
}
else
{
p=p->next;
q=q->next;
}
}
printf("删除成功!!");
}
//在升序链表中,插入新的元素,扔有序
void Insert(LinkList L,LinkList p)
{
LinkList s;
s=L;
while(s->next && s->next->data<p->data)
s=s->next;
p->next=s->next;
s->next=p;
}
//提示界面显示
void Tips()
{
printf("\n");
printf("根据按键选择相应的操作:\n");
printf("<1>输出单链表及其长度:\n");
printf("<2>查找值为x的直接前驱结点:\n");
printf("<3>删除值为x的结点:\n");
printf("<4>将表中的元素逆置:\n");
printf("<5>将单链表由小到大进行排序:\n");
printf("<6>删除表中相同的元素:\n");
printf("<7>在升序链表中插入元素x:\n");
printf("<0>退出:\n");
}
//主函数
void main()
{
int op,x;
LinkList L,p;
L = (LinkList)malloc(sizeof(LNode));
L->next=NULL;
L->data=-1;
Build(L);
Tips();
scanf("%d",&op);
while(op)
{
switch(op)
{
case 1:LinkLength(L);
break;
case 2:
printf("请输入要查找的元素x:\n");
scanf("%d",&x);
Find(L,x);
break;
case 3:
printf("请输入要删除的元素x:\n");
scanf("%d",&x);
Delete(L,x);
break;
case 4:Reverse(L);
break;
case 5:sort(L);
break;
case 6:Deletesameelem(L);
break;
case 7:
printf("请输入要插入的元素X:\n");
scanf("%d",&x);
p=(LinkList)malloc(sizeof(LNode));
p->data=x;
Insert(L,p);
printf("插入成功!!!\n\n");
break;
}
scanf("%d",&op);
}
}
|








发表评论
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。