zoukankan      html  css  js  c++  java
  • 单链表中重复元素的删除 分类: 链表 2015-06-08 08:14 15人阅读 评论(0) 收藏

    数据结构实验之链表七:单链表中重复元素的删除

    TimeLimit: 1000MS Memory limit: 65536K

    题目描述

    按照数据输入的相反顺序(逆位序)建立一个单链表,并将单链表中重复的元素删除(值相同的元素只保留最后输入的一个)。

    输入

    第一行输入元素个数n

    第二行输入n个整数。

    输出

    第一行输出初始链表元素个数;

    第二行输出按照逆位序所建立的初始链表;

    第三行输出删除重复元素后的单链表元素个数;

    第四行输出删除重复元素后的单链表。

    示例输入

    10

    2130 14 55 32 63 11 30 55 30

    示例输出

    10

    3055 30 11 63 32 55 14 30 21

    7

    3055 11 63 32 14 21

    #include <bits/stdc++.h>
    #define RR freopen("input.txt","r",stdin)
    #define WW freopen("output.txt","w",stdout)
    using namespace std;
    const int mod=10007;
    struct node
    {
        int data;
        node *next;
    };
    int main()
    {
        int n;
        node *head,*p,*tail,*q;
        head=new node;
        head->next=NULL;
        cin>>n;
        for(int i=1; i<=n; i++)
        {
            p=new node;
            p->next=head->next;
            cin>>p->data;
            head->next=p;
        }
        cout<<n<<endl;
        p=head->next;
        while(p)
        {
            if(p!=head->next)
                cout<<" ";
            cout<<p->data;
            p=p->next;
        }
        cout<<endl;
        p=head->next;
        while(p)
        {
            q=p;
            tail=p->next;
            while(tail)
            {
                if(tail->data==p->data)
                {
                    q->next=tail->next;
                    free(tail);
                    tail=q->next;
                    n--;
                }
                else
                {
                    q=q->next;
                    tail=tail->next;
                }
            }
            p=p->next;
        }
        cout<<n<<endl;
        p=head->next;
        while(p)
        {
            if(p!=head->next)
            {
                cout<<" ";
            }
            cout<<p->data;
            p=p->next;
        }
        cout<<endl;
        return 0;
    }
    


    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    UE4项目《和平精英》渲染技术浅析
    如何用CMake构建Android C++库
    Unity Native Plugin
    多边形三角化
    参考图
    Unity SRP学习笔记
    Macbook Pro HDMI 无信号解决办法
    CGAL计算几何算法库
    无标记动作捕捉
    PS 鼠绘
  • 原文地址:https://www.cnblogs.com/juechen/p/4722059.html
Copyright © 2011-2022 走看看