标题:链式存储线性表中删除第i个结点
只看楼主
sndupi
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-4-7
结帖率:0
已结贴  问题点数:20 回复次数:8 
链式存储线性表中删除第i个结点
求C程序 链式存储线性表中删除第i个结点 在线等  急!!!!!!
搜索更多相关主题的帖子: 删除 线性 结点 链式 
2010-04-07 17:48
sndupi
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-4-7
得分:0 
自己顶
2010-04-07 17:51
sndupi
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-4-7
得分:0 
高手们快来帮帮忙啊!!!!在线等
2010-04-07 18:05
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
得分:5 
书上了 百度了 到处是
2010-04-07 18:28
studythec
Rank: 1
来 自:安徽阜阳
等 级:新手上路
帖 子:31
专家分:5
注 册:2010-3-13
得分:5 
#include<iostream.h>
#include<string.h>
#include<stdlib.h>
#define NULL 0                                 //宏定义NULL为0
#define SIZ sizeof(struct stu)                 //宏定义 SIZ为sizeof(struct stu)
struct stu                                      //结构体
{
    int num;
    stu *next;
};                                                     
        
void main()
{
    stu *H=NULL;      //定义头指针
    stu *r,*s,*p,*q;                                          
    int x,y;
    cin>>x;
    r=NULL;                //建立单链表A
    while(x!=NULL)                              
    {                       
        s=(stu*) malloc(SIZ);
        s->num=x;
        if(H==NULL)
            H=s;
        else
            r->next=s;
        r=s;
        cin>>x;                  
    }                           
    if(r!=NULL)
        r->next=NULL;
    r=H;
    while(r!=NULL)           //输出单链表A
    {
        cout<<r->num<<" ";
        r=r->next;
    }
    cout<<endl;
    cin>>y;                 //输入要插入的数据
    r=H;
    p=H;                        //指向头结点
    s=(stu*) malloc(SIZ);       //申请空间
    s->num=y;
    if(H==NULL)                  //头结点为空,使头结点指向S
        H=s;
    else                      //头结点不为空,插入S
        while(p->num<s->num)   
        {
            if(p->next->num>s->num)
            {
                q=p->next;
                s->next=q;
                p->next=s;
            }
            p=p->next;
        }
    r=H;
    while(r!=NULL)
    {
        cout<<r->num<<" ";
        r=r->next;
    }
    cout<<endl;
}

菜鸟一个,在校学习,多多指教!
2010-04-07 19:34
sndupi
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-4-7
得分:0 
回复 5楼 studythec
谢谢回答  可是你给的是插入啊 我要删除的 能帮下忙吗?
2010-04-07 19:49
studythec
Rank: 1
来 自:安徽阜阳
等 级:新手上路
帖 子:31
专家分:5
注 册:2010-3-13
得分:0 
e搞错

菜鸟一个,在校学习,多多指教!
2010-04-07 20:13
广陵绝唱
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:29
帖 子:3607
专家分:1709
注 册:2008-2-15
得分:5 
struct st *del_line(struct st *head,int i)
{
        struct st *t,*pr;

        t=head;
         for(int j=0;j<i&&t->next;++j)
        {
                pr=t;
                t=t->next;
        }
        if(t)
        {
                pr->next=t->next;
                free(t);
        }

        return head;
}
        

没编译运行,大致意思就是这样的.

[ 本帖最后由 广陵绝唱 于 2010-4-7 20:18 编辑 ]
2010-04-07 20:16
zhangbohtz
Rank: 2
等 级:论坛游民
帖 子:36
专家分:39
注 册:2010-1-29
得分:5 
自己画个图就明白了,
你要的是那种连表呢?
循环,单向,带头节点,还是头指针?
问题都不清楚!
不过原理一样,最好是先画画,我是这样学过来的!
画图很重要!
2010-04-09 18:22



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-302008-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.146332 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved