美文网首页
算法概论

算法概论

作者: 你猪头啊 | 来源:发表于2019-03-18 19:03 被阅读0次

题目:

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;
}

相关文章

  • 给我巨大影响的技术书籍

    算法《算法概论》《算法设计与分析基础》 Anany Levitin《算法引论》Udi Manber《算法导论》《什...

  • 算法概论

    题目: 2.14 给定一个含有n个元素的数组,注意到数组中的某些元素是重复的,即这些元素在数组中出现不止一次。给出...

  • 算法概论

    1.监督学习和无监督学习: 监督学习(supervised learning): 输入数据有特征值和标签值,利...

  • 算法概论

    1.算法定义 算法是一组有穷的规则,它规定了解决某一特定类型问题的一系列计算方法 2.算法的五个特性 确定性:无二...

  • 常见算法概论

    前言 算法与数据结构是计算机科学中的核心内容,算法是研究解决问题的方法,而数据结构则是设计一种更好的组织和使用数据...

  • 二、算法概论

    1.概念 算法是解决特定问题求解步骤的描述,在计算机中表现为指令的有限序列,并且每条指令表示一个或多个操作。 2...

  • 二、算法概论

    数据结构目录 1.概念 算法是解决特定问题求解步骤的描述,在计算机中表现为指令的有限序列,并且每条指令表示一个或多...

  • 算法概论笔记 - 图

    现实生活中有很大一类问题可以用简洁明了的图论语言来描述,可以转化为图论问题。 相关定义 图可以表示为G=(V, E...

  • 《算法概论》习题8.10

    a. 令图G 为一个环,环上的顶点数等于图 H 的顶点数。那么若G 是 H 的同构子图,则说明 H 存在 Rudr...

  • 常用密码算法

    概论 在平时的开发过程中,我们基本上会使用到对称加解密算法,非对称加解密算法以及摘要算法。虽然有很多轮子可供开发者...

网友评论

      本文标题:算法概论

      本文链接:https://www.haomeiwen.com/subject/uxgbmqtx.html