单链表的创建、插入,删除、查找等操作

 
#include < stdio.h >
#include
< malloc.h >

typedef 
struct  node  // 定义链表
{
    
int data;
    
struct node *next;
}
snode;

snode
*  creat()  // 创建链表的函数
{
    snode 
*head, *p, *q;
    head 
= (snode *)malloc(sizeof(snode));
    p 
= head;
    
int x;
    printf(
"请输入创建链表的值,用-1结束输入 ");
    printf(
"x = ");
    scanf(
"%d"&x);
    
while (x != -1)
    
{
        q 
= (snode *)malloc(sizeof(snode));
        q
->data = x;
        p
->next = q;
        p 
= q;
        printf(
"x = ");
        scanf(
"%d"&x);
    }

    p
->next = NULL;
    
return head;
}

int  length(snode  * head) // 测链表的结点数
{
    snode 
*= head->next;
    
int i = 0;
    
while (p != NULL)
    
{
        p 
= p->next;
        i
++;
    }

    
return i;
}

void  display(snode  * head)  // 依次输出每个结点的值
{
    snode 
*= head->next;
    
for(int i = 0; i < length(head); i++)
    
{
        printf(
"%4d", p->data);
        p 
= p->next;
    }

    printf(
" ");
}


int  locate(snode  * head,  int  x)  // 测x在链表中的位置
{
    snode 
*= head->next;
    
int i = 1;
    
while (p != NULL && x != p->data)
    
{
        p 
= p->next;
        i
++;
    }

    
if (p == NULL) //什么叫等于,两个等号才叫等于.
        return 0;
    
else
        
return i;
}


int  insnode(snode  * head,  int  x,  int  i)  // 把x插入到链表的第i的位置
{
    snode 
*= head->next, *s;
    
int j;
    
if(i < 1 || i > length(head) + 1)
        
return 0;
    
else if (i == 1)
    
{
        s 
= (snode *)malloc(sizeof(snode));
        s
->next = p;
        head
->next = s;
        s
->data = x;
    }

    
else
    
{
        
for (j = 1; j < i - 1; j++)
        p 
= p->next;
        s 
= (snode *)malloc(sizeof(snode));
        s
->next = p->next;
        p
->next = s;
        s
->data = x;
    }

    
return 1;
}


int  delnode(snode  * head,  int  i) // 删除链表中第i个结点
{
    snode 
*= head->next, *= head;
    
if(i < 1 || i > length(head))
        
return 0;
    
else if (i == 1)
    
{
        head
->next = p->next;
        free(p);
    }

    
else
    
{
        
for (int j = 1; j < i; j++)
        
{
            p 
= p->next;
            q 
= q->next;
        }

        q
->next = p->next;
        free(p);
    }

    
return 1;
}


void  sort(snode  * head)  // 把链表中每个结点的值按从小到大排列
{
    snode 
*p, *q;
    
int k;
    
for(p = head->next; p != NULL; p = p->next)
        
for(q = p->next; q != NULL; q = q->next)
            
if (p->data > q->data)
            
{
                k 
= p->data;
                p
->data = q->data;
                q
->data = k;
            }

}


void  insert(snode  * head,  int  x)  // 在有序链表中插入x,插入后仍保持有序
{
    snode 
*= head->next, *s, *= head;
    
while (p != NULL && p->data < x)
    
{
        q 
= q->next;
        p 
= p->next;
    }

    s 
= (snode *)malloc(sizeof(snode));
    s
->next = q->next;
    s
->data = x;
    q
->next = s;
}


void  del_min_max(snode  * head,  int  min,  int  max)  // 删除有序链表中值min到值max中的结点
{
    snode 
*= head->next, *= head;
    
while (p != NULL && p->data <= min)
    
{
        q 
= p;
        p 
= p->next;
    }

    
while (p != NULL && p->data < max)
    
{
        q
->next = p->next;
        free(p);
        p 
= q->next;
    }

}


void  del_min(snode  * head)  //  删除数据域最小的结点
{
    snode 
*= head->next, *= head;
    snode 
*p_min, *q_min;
    p_min 
= p;
    q_min 
= q;
    
while (p != NULL)
    
{
        q 
= p;
        p 
= p->next;
        
if (p != NULL && p->data < p_min->data)
        
{
            q_min 
= p_min;
            p_min 
= p;
        }

    }

    q_min
->next = p_min->next;
    free(p_min);
}


int  main( void )
{
    snode 
*headl = creat(); //创建链表
    printf("最初的链表如下: ");
    display(headl);
    
int num, location;
    printf(
"请输入您要查找的数:");
    scanf(
"%d"&num);
    
if (locate(headl, num))
        printf(
"数字%d在链表中的位置为%d ", num, locate(headl, num));
    
else
        printf(
"数字%d在链表中不存在 ", num);
    printf(
"请分别输入您要插入到链表中的数以及想插入的位置:");
    scanf(
"%d %d"&num, &location);
    
if (insnode(headl, num, location))
    
{
        printf(
"插入新值以后的链表如下: ");
        display(headl);
    }

    
else
        printf(
"输入有误 ");
    printf(
"请输入您想删除的结点位置:");
    scanf(
"%d"&location);
    
if (delnode(headl, location))
    
{
        printf(
"删除第%d个结点后的链表如下: ", location);
        display(headl);
    }

    
else
        printf(
"输入有误! ");
    sort(headl); 
//排序
    printf("经过把结点数据按从小到大排序以后的链表如下: ");
    display(headl);
    printf(
"请输入一个将被插入到有序链表中的数:");
    scanf(
"%d"&num);
    insert(headl, num);
    printf(
"将%d插入到有序链表中后,链表仍然有序,如下: ", num);
    display(headl);
    
int min, max;
    printf(
"请输入需要删除的一段结点的头和尾,他们之间的结点将被删除:");
    scanf(
"%d %d"&min, &max);
    del_min_max(headl, min, max);
    printf(
"经过删除以后的链表如下: ");
    display(headl);
    printf(
"经过删除最小数据域的结点以后的链表如下: ");
    del_min(headl);
    display(headl);
}
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,我可以回答这个问题。下面是单链表创建插入删除查找和显示的基本操作: 1. 创建单链表单链表是由若干个结点组成的,每个结点包含两部分:数据域和指针域。数据域用来存储数据,指针域用来指向下一个结点。创建一个单链表的基本步骤如下: (1)定义一个结点结构体,包含数据域和指针域。 (2)定义头结点指针,指向链表的第一个结点。 (3)逐个创建结点,将它们按顺序连接起来。 2. 插入结点: 插入结点是指在链表的某个位置上插入一个新结点。插入结点的基本步骤如下: (1)找到要插入位置的前一个结点。 (2)创建一个新结点,将数据存入其中。 (3)将新结点的指针域指向原来位置上的结点。 (4)将前一个结点的指针域指向新结点。 3. 删除结点: 删除结点是指在链表的某个位置上删除一个结点。删除结点的基本步骤如下: (1)找到要删除的结点。 (2)将要删除结点的前一个结点的指针域指向要删除结点的下一个结点。 (3)释放要删除的结点。 4. 查找结点: 查找结点是指在链表中查找某个特定的结点。查找结点的基本步骤如下: (1)从链表的第一个结点开始遍历,直到找到要查找的结点。 (2)如果找到了,返回该结点;否则返回空指针。 5. 显示链表: 显示链表是指将链表中所有结点的数据依次输出。显示链表的基本步骤如下: (1)从链表的第一个结点开始遍历,依次输出每个结点的数据。 (2)遍历完毕后,输出结束标志。 希望这些基本操作对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值