算法概论

题目:

2.14 给定一个含有n个元素的数组,注意到数组中的某些元素是重复的,即这些元素在数组中出现不止一次。给出一种算法,以O(nlogn)时间移除掉数组中的所有重复元素。

算法思想:

时间复杂度是O(nlogn),移除重复元素,可以先将重复元素排到一起,即排序,这里采用归并排序,将数组有序排好,再进行一次扫描,将重复元素删除。时间复杂度为:O(nlogn)+O(n)=O(nlogn)

代码:

#include <iostream>
#include<vector>
constexpr auto INFINITE = 1000000;
using namespace std;
void merge(vector<int>&a, int l1, int r1, int l2, int r2)
{
    int i = l1;
    int j = l2;
    int n = (r1 - l1 + 1) + (r2 - l2 + 1);
    vector<int>temp(n);
    int k = 0;
    while (i <= r1 && j <= r2)
    {
        if (a[i] < a[j])
            temp[k++] = a[i++];
        else
            temp[k++] = a[j++];
    }
    while (i <= r1)
        temp[k++] = a[i++];
    while (j <= r2)
        temp[k++] = a[j++];
    for (int i = 0; i < temp.size(); i++)
    {
        a[l1 + i] = temp[i];
    }
}
void MergeSort(vector<int>&a, int Start, int End)//递归
{
    if (Start < End)
    {
        int mid = (Start + End) >> 1;
        MergeSort(a, Start, mid);
        MergeSort(a, mid + 1, End);
        merge(a, Start, mid, mid + 1, End);
    }
}
int main(void)
{
    vector<int>A;
    int n;
    cin >> n;
    for (int i = 0; i < n; i++)
    {
        int temp;
        cin >> temp;
        A.push_back(temp);
    }
    MergeSort(A, 0, A.size() - 1);
    vector<int>result;
    if (A[0] != A[1])
        result.push_back(A[0]);
    for (int i = 1; i < A.size()-1; i++)
    {
        if (A[i] != A[i - 1] && A[i] != A[i + 1])
            result.push_back(A[i]);
    }
    if (A[A.size() - 1] != A[A.size() - 2])
        result.push_back(A[A.size() - 1]);
    for (int i = 0; i < result.size(); i++)
    {
        cout << result[i] << " ";
    }
    cout << endl;
    system("pause");
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 将原问题分解为一组子问题,每个子问题都与原问题类型相同,但是比原问题的规模小 递归求解这些子问题 将子问题的求解结...
    芥丶未央阅读 5,295评论 2 1
  • 1 初级排序算法 排序算法关注的主要是重新排列数组元素,其中每个元素都有一个主键。排序算法是将所有元素主键按某种方...
    深度沉迷学习阅读 5,316评论 0 1
  • 搞懂基本排序算法 上篇文章写了关于 Java 内部类的基本知识,感兴趣的朋友可以去看一下:搞懂 JAVA 内部类;...
    醒着的码者阅读 4,941评论 3 4
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,583评论 0 52
  • 我到达马德里的那天夜晚,正好赶上了万圣之夜。我倒没有刻意算过日子,直到看到街头巷尾到处可见的灵异装扮,才提醒了我这...
    索莱耶阅读 3,989评论 2 21