本文介绍: 本关任务利用链表表示一个递增的整数序列删除链表中值大于等于mink且小于等于maxk所有元素minkmaxk给定两个参数,其值可以表中的元素相同,也可以不同)。多组数据,每组数据有两行第一行链表长度n第二行为链表的n个元素(元素之间空格分隔),第三行为给定minkmaxk(用空格分隔)。当n=0时输入结束。对于每组数据分别输出一行,依次输出删除元素后的链表元素,元素之间空格分隔。开始你的任务吧,祝你成功

任务描述

本关任务利用单链表示一个递增的整数序列删除表中大于等于mink且小于等于maxk所有元素(minkmaxk是给定的两个参数,其值可以表中的元素相同,也可以不同)。

编程要求

输入

组数据,每组数据有两行第一行为链表的长度n第二行为链表的n个元素(元素之间用空格分隔),第三行为给定的minkmaxk(用空格分隔)。当n=0时输入结束

输出

对于每组数据分别输一行,依次输出删除元素后的链表元素,元素之间用空格分隔

测试说明

平台会对你编写代码进行测试

测试输入5 1 2 3 4 5 2 4 6 2 4 6 8 10 12 3 5 0

预期输出: 1 5 2 6 8 10 12

来源

BJFUOJ


开始你的任务吧,祝你成功

#include <iostream>
using namespace std;
typedef struct LNode
{
    int data;
    struct LNode *next;
}LNode,*LinkList;
void CreateList_R(LinkList &L,int n)
{//后插法创建单链表
    L=new LNode;
    L->next=NULL;
    LinkList r=L;
    for(int i=0;i<n;i++)
    {
        LinkList p=new LNode;
        cin&gt;&gt;p-&gt;data;
        p-&gt;next=NULL;
        r-&gt;next=p;
        r=p;
    }
}
void PrintList(LinkList &amp;L)
{//打印依次输出链表中数据
    L=L-&gt;next;
    while(L){
        if(L->next!=NULL) cout<<L->data<<" ";
        else cout<<L->data;
        L=L->next;
    }
    cout<<endl;
}
void DeleteMinMax(LinkList &amp;L,int mink,int maxk)
{//删除表中满足区间值的结点
/**************begin************/
LinkList p=L->next,pre=L;
while(p)
{
    if(p->data>=mink &amp;&amp; p->data <= maxk)
    {
        pre->next=p->next;
        p=p->next;
    }
    else
    {
        p=p->next;
        pre=pre->next;
    }
}




/**************end************/
}
int main()
{
    int n;
    while(cin>>n)
    {
        if(n==0) break;
        LinkList L;
        CreateList_R(L,n);
        int mink,maxk;
        cin>>mink>>maxk;
        DeleteMinMax(L,mink,maxk);
        PrintList(L);
    }
    return 0;
}

原文地址:https://blog.csdn.net/qq_74118294/article/details/134818892

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_47610.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注