51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1099|回复: 8
打印 上一主题 下一主题

自己写的一个关于链表的插入删除的操作,请高手们看看有哪里不妥。

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2007-11-27 21:09:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
都没有人啊。

[ 本帖最后由 zhanglei_317 于 2007-11-28 16:39 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2007-12-5 14:15:52 | 只看该作者
typedef struct Node
{
        int data;
        Node *next;    /*这个地方要改成 struct Node *next*/
}Lnode,*LinkList;
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2007-12-5 14:16:27 | 只看该作者
所有用Node定义的变量,全改成Lnode
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2007-12-5 14:26:48 | 只看该作者
把main函数的字符变量tem写在while循环的外面
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2007-12-5 14:27:32 | 只看该作者
是tmp,写错了
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2007-12-5 14:40:46 | 只看该作者
Lnode *Delete(Lnode *head,int DelNum) /*这里DelNum作为参数传给Delete函数*/
{
        Lnode *p6,*p7;
        p6 = NULL;
        p7 = NULL;
        p6 = (LinkList)malloc(sizeof(Lnode));
        p7 = (LinkList)malloc(sizeof(Lnode));
        printf("please input the deletenumber:");
        scanf("%d",&DelNum); /*这里要scanf干嘛?*/
        p6 = head;
        if (head == NULL)
        {
                printf("the list is null\n");
        }
        else
        {
                p6 = head;
                while (DelNum != p6->data && p6 ->next !=NULL )
                {
                        p7 = p6;
                        p6 = p6 ->next ;
                }

                if (DelNum == p6->data )
                {
                        if(p6 == head)
                        {       
                                head = p6->next ;
                        }
                        else
                        {
                                p7->next = p6->next ;
                        }
                }
                else
                {
                        printf("no this number!\n");
                }
       

        }
        return head;
       
}
回复 支持 反对

使用道具 举报

该用户从未签到

7#
发表于 2007-12-5 14:46:16 | 只看该作者
case 5:
                        {
                                printf("输入要删除的节点\n");/*这句是我加的*/
                                scanf("%d",&DelNum);/*这句是我加的*/
                                head = Delete(head,DelNum);
                                view(head);
                                break;
                        }
回复 支持 反对

使用道具 举报

该用户从未签到

8#
发表于 2007-12-5 14:47:25 | 只看该作者
Lnode *Insertmid(Lnode *head)
{
        int i,j=1; /*这两个变量的定义我把它们提前了,原来是在p5=NULL后面的*/
        Lnode *p4,*p5;
        p4 = NULL;
        p5 = NULL;
回复 支持 反对

使用道具 举报

该用户从未签到

9#
发表于 2007-12-5 14:47:42 | 只看该作者
改过这些基本上就OK了
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-17 16:33 , Processed in 0.068592 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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