单链表反转(acm模式)删除重复元素

#include<iostream>
#include<vector>
using namespace std;
struct LinkNode//链表结构体
{
  int val;
  LinkNode *next;
  LinkNode(int val):val(val),next(nullptr){}
};
LinkNode *_dummyHead= new LinkNode(0);//头节点
void show(LinkNode *head)//展示
{
    LinkNode *cur=head;//代替头节点,方便遍历
    while(cur!=nullptr)
    {
        cout<<cur->val<<" ";
        cur=cur->next;
    }
    cout<<endl;
    
}

LinkNode* reverse(LinkNode *head)//反致链表
{
    LinkNode *temp;
    LinkNode *per=nullptr;//前置节点,挺不好想,需要temp,per,cur
    LinkNode *cur=head;
    while(cur)
    {
        temp=cur->next;//保存下一个节点
        cur->next=per;//开始反制了,先节点指向前节点
        per=cur;
        cur=temp;
    }
    return per;
}

int main()
{
    int n, num;
  
    while(cin>>n)
    {
        if(n==0)
        {
            cout<<"list is empty"<<endl;
            continue;
        }
            
        LinkNode *cur=_dummyHead;//此处定义应在循环里面
        while(n--)
        {
            cin>>num;
            LinkNode *newnode= new LinkNode(num);
            cur->next=newnode;
            cur=cur->next;
        }
        show(_dummyHead->next);
        show(reverse(_dummyHead->next));
    }
   
    
    
    
    return 0;
}

下面这道题,希望你手到擒来 ,两题结构上基本一致,除细微删除输出,可以建立数组,将不重复数字加入,每次判断是否有输出资格,用flag来标记,这里我为什么使用vector容器,因为之前建立的固定数组,总是判定为可能存在数字越界问题,主要因为输入的数组大小也不固定。num.push_back将数字加入到容器尾部,不影响输出,num数组只作为重复性检查

 

#include<iostream>
#include<vector>
using namespace std;
struct linknode {
    int val;
    linknode* next;
    linknode(int val) :val(val), next(NULL) {}
};
linknode* dummyhead = new linknode(0);
void deletemult(linknode* head)
{
    linknode* cur = head;
    vector<int> num;
    int count = 0;
    while (cur != nullptr)
    {
        int flag = 1;
        for (int j = 0; j < count; j++)
        {
            if (num[j] == cur->val)
            {
                flag = 0;
                break;
            }
        }
        if (flag)
        {
            //cout<<cur->val<<" ";
            num.push_back(cur->val);
            cout <<cur->val << " ";
            count++;
        }
        cur = cur->next;
    }
    cout << endl;

}
void show(linknode* head)
{
    linknode* cur = head;
    while (cur != NULL)
    {
        cout << cur->val << " ";
        cur = cur->next;
    }
    cout << endl;
}

int main()
{
    int n, m;
    while (cin >> n)
    {
        if (n == 0)
        {
            cout << "list is empty" << endl;
            continue;
        }
        linknode* cur = dummyhead;
        while (n--)
        {
            cin >> m;
            linknode* newnode = new linknode(m);
            cur->next = newnode;
            cur = cur->next;
        }
        show(dummyhead->next);
        deletemult(dummyhead->next);
    }
    return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大肥羊学校懒羊羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值