栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

6-7 删除循环链表中已知结点的前驱 (10 分)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

6-7 删除循环链表中已知结点的前驱 (10 分)

6-7 删除循环链表中已知结点的前驱 (10 分)

假设有一个循环链表的长度大于1,且表中既无头节点也无头指针。已知s为指向链表中某结点的指针,试编写算法,在链表中删除指针s所指结点的前驱结点。
函数接口定义:

void DelPrior (Node * s );

其中 s 是传入的参数,函数要求删除s所指结点的前驱结点。其中类型定义如下:

typedef int DataType;
typedef struct node
{
    DataType data;
    struct node *next;
}LNode,*linkList;

裁判测试程序样例:

#include 
#include 
typedef int DataType;
typedef struct node 
{
    DataType data;
    struct node *next;
}LNode,*linkList;

linkList Creat_CircularList(); //创建无头结点循环单链表,并返回头指针。
LNode * SetPointerS(linkList H,int x);//返回指向第x个结点的指针。
void PrintCircularList(LNode *S);//从指针S所指结点开始,依次输出各个结点的值。

void DelPrior(LNode *S);
main()
{
    LNode *s;
    linkList H;
    int x;
    H = Creat_CircularList();
    scanf("%d",&x);
    s=SetPointerS(H,x);
    DelPrior(s);
    PrintCircularList(s);
}

linkList Creat_CircularList()
{
    int n,i;
    LNode *nw,*rear=NULL,*head=NULL;
    scanf("%d",&n);//接收结点总数
    for(i=0;idata);
        if(rear==NULL)
            rear=head=nw;
        else
        {
            rear->next=nw;
            rear=nw;
        }
    }
    if(rear)
        rear->next=head;
    return head;
}

void PrintCircularList(linkList s)
{
    LNode *p;
    for(p=s;p->next!=s;p=p->next)
        printf("%d ",p->data);
    printf("%d",p->data);
}

LNode * SetPointerS(linkList H,int x)
{
    int i;
    LNode *s=H;
    for(i=1;inext;
    return s;
 }



输入样例:

在这里给出一组输入。例如:

5
1 2 3 4 5
4

输出样例:

在这里给出相应的输出。例如:

4 5 1 2
void DelPrior(LNode *s){
	int a;
	LNode *p,*q;//q为要删除结点,即s的前驱;p为q的前驱结点 
	p=q=s;
	while(q->next!=s){
		q=q->next;
	}
	while(p->next!=q)
	p=p->next;
	a=q->data;
	p->next=s;
	free(q);
}

算法思路:设置两个p,q结点将一个结点q移动到s指针所指到的位置之前,再将p指针移动到q指针之前将q指针所指的内容删除,并释放内存。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/744172.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号