任务描述
本关任务:利用单链表表示一个递增的整数序列,删除链表中值大于等于mink且小于等于maxk的所有元素(mink和maxk是给定的两个参数,其值可以和表中的元素相同,也可以不同)。
编程要求
输入
多组数据,每组数据有两行,第一行为链表的长度n,第二行为链表的n个元素(元素之间用空格分隔),第三行为给定的mink和maxk(用空格分隔)。当n=0时输入结束。
输出
对于每组数据分别输出一行,依次输出删除元素后的链表元素,元素之间用空格分隔。
测试说明
平台会对你编写的代码进行测试:
代码
#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;
int i;
LinkList p=L;
for(i=1;i<=n;i++){
LinkList s;
s=new LNode;
scanf("%d",&s->data);
s->next=NULL;
p->next=s;
p=s;
}
}
LinkList DeleteMinMax(LinkList& L, int mink, int maxk)
{//删除链表中满足区间值的结点
LinkList p = L;
while (p -> next)
{
if (p -> next -> data >= mink && p -> next -> data <= maxk)
{
LNode *tmp = p -> next;
p -> next = p -> next -> next;
delete tmp;
}
else p = p -> next; // 这个else一定要加上,不然就会重复进行后移操作
}
p -> next = NULL;
return L;
}