鱼C论坛

 找回密码
 立即注册
查看: 1170|回复: 4

[已解决]单链表实现增、删、查

[复制链接]
发表于 2020-9-28 19:20:34 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
心态炸了,这个bug改了一个多小时了,其他没问题,删除函数那里的问题,请大佬看看
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct array
{
                int value;
                struct array *next;
}ARRAY;

void insert(ARRAY **head);
void delete(ARRAY **head);
void search(ARRAY *head);
void print(ARRAY *head);

int main(void)
{
                ARRAY *head = NULL; // 创建头指针
                
                while(1)
                {
                        printf("--------------------------\n");
                        printf("0.退出程序      1.插入数据\n");
                        printf("2.删除数据      3.查找元素\n");
                        printf("--------------------------\n");
                        
                        int input;
                        printf("请输入待执行的功能:");
                        scanf("%d",&input);
                        
                        if(input < 0 || input > 3)
                        {
                                printf("输入有误,请重新输入\n\n");
                                continue;
                        }
                        
                        switch(input)
                        {
                                case 0:
                                        printf("成功退出程序,欢迎下次再来\n");
                                        exit(1);
                                case 1:
                                        insert(&head);
                                        print(head);
                                        break;
                                case 2:
                                        delete(&head);
                                        print(head);
                                        break;
                                case 3:
                                        search(head);
                                        break;
                        }
                } 
}

// 插入函数 
void insert(ARRAY **head)
{
                ARRAY *previous = *head;
                ARRAY *new;
                
                new = (ARRAY *)malloc(sizeof(ARRAY)); // 开辟新的空间 
                
                if(new == NULL)
                {
                        printf("内存分配失败,退出程序\n");
                        exit(1);
                }
                
                printf("请输入一个整数:");
                scanf("%d",&new->value);
                
                if(*head != NULL)
                {
                        while(previous->next != NULL)
                        {
                                previous = previous->next;
                        }
                        previous->next = new;
                        new->next = NULL;
                }
                else
                {
                        *head = new;
                        new->next = NULL;
                }
}

// 删除函数 
void delete(ARRAY **head)
{
                int flag = 0;
                ARRAY *current = *head;
                ARRAY *previous;
                int num;
                printf("请输入一个整数:");
                scanf("%d",&num);
                
                while(current !=  NULL)
                {
                        if(current->value == num)
                        {
                                printf("找到了,开始删除....");
                                flag = 1;
                                previous = current;
                                free(previous);
                        }
                        current = current->next;
                }
                
                if(flag == 0)
                {
                        printf("没有找到该数值,删除失败\n"); // 遍历完链表没有找到 
                }
                
}


// 查找函数 
void search(ARRAY *head)
{
                int n = 0, flag = 0;
                
                ARRAY *current = head;
                int num;
                printf("请输入一个整数:");
                scanf("%d",&num);
                
                while(current !=  NULL)
                {
                        n++;
                        if(current->value == num) // 有可能存在重复数据,遍历到尾节点 
                        {
                                flag = 1; // 查找成功,flag = 1 
                                printf("查找成功,是第%d个数\n",n);
                        }
                        current = current->next;
                }
                
                if(flag == 0)
                {
                        printf("没有找到该数值,查找失败\n"); // 遍历完链表没有找到 
                }
                
                putchar('\n');
                
}

// 打印函数 
void print(ARRAY *head)
{
                ARRAY *current = head;
                
                while(current != NULL)
                {
                        printf("%d ",current->value);
                        current = current->next;
                }
                
                printf("\n\n");
}
最佳答案
2020-9-28 20:13:08
本帖最后由 xieglt 于 2020-9-29 08:43 编辑
// 删除函数 
void delete1(ARRAY **head)
{
                int flag = 0;
                ARRAY *current = *head;
                ARRAY *previous;
                int num;
                printf("请输入一个整数:");
                scanf("%d",&num);
                                
               //如果head是输入的数
                if(*head != NULL && (*head)->value == num)
                {
                        *head = (*head)->next;
                        free(current);
                        flag = 1;
                }
                else if(current != NULL)
                {

                do
                {
                        previous = current;
                        current = current->next;

                        if(current == NULL)
                        {
                            break;
                        }

                        if(current->value == num)
                        {
                                previous->next = current->next;
                                printf("找到了,开始删除....");
                                flag = 1;
                                free(current);
                                break;
                        }
                }while(1);
        }
                
        if(flag == 0)
         {
                printf("没有找到该数值,删除失败\n"); // 遍历完链表没有找到 
          }
                
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-9-28 20:13:08 | 显示全部楼层    本楼为最佳答案   
本帖最后由 xieglt 于 2020-9-29 08:43 编辑
// 删除函数 
void delete1(ARRAY **head)
{
                int flag = 0;
                ARRAY *current = *head;
                ARRAY *previous;
                int num;
                printf("请输入一个整数:");
                scanf("%d",&num);
                                
               //如果head是输入的数
                if(*head != NULL && (*head)->value == num)
                {
                        *head = (*head)->next;
                        free(current);
                        flag = 1;
                }
                else if(current != NULL)
                {

                do
                {
                        previous = current;
                        current = current->next;

                        if(current == NULL)
                        {
                            break;
                        }

                        if(current->value == num)
                        {
                                previous->next = current->next;
                                printf("找到了,开始删除....");
                                flag = 1;
                                free(current);
                                break;
                        }
                }while(1);
        }
                
        if(flag == 0)
         {
                printf("没有找到该数值,删除失败\n"); // 遍历完链表没有找到 
          }
                
}

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
巴巴鲁 + 5 + 5 + 3

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-29 11:33:32 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-29 11:58:45 | 显示全部楼层
我测试可以的
未命名.JPG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-29 12:19:26 | 显示全部楼层
行了,感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 03:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表