检查两个数组是否相等

Check if two arrays are equal or not

我想知道两个给定的数组是否相等,无论元素的排列如何但包含相同的元素并且所有元素的频率必须相同。

    int SameArray(int arr1[], int arr2[], int N, int M)
    {
        unordered_map<int, int> ump;
        if(N == M)
        {
            for(int i = 0; i < N; i++)
            {
                ump[arr1[i]]++;
            }
            for(int i = 0; i< M; i++)
            {
                if(ump.find(arr2[i]) != ump.end())
                    ump[arr2[i]]--;
            }
            if(ump.empty())
            return 1;
        }
        return 0;
    }

它没有显示任何错误,但输出始终为 0。

您正在寻找 std::is_permutation:

bool SameArray(const std::vector<int>& arr1, const std::vector<int>& arr2) {
    return std::is_permutation(arr1.begin(), arr1.end(), arr2.begin(), arr2.end());
}

我冒昧地将你的函数 return 更改为 bool 并将 std::vectors 作为函数参数,因为这是 C++ 而不是 C。

如果您对 std::permutation 的比较如何工作感到好奇,请查看它的 example implementation

您需要检查映射中的每个键的值是否为零。您可以执行以下代码,而不是 ump.empty()

for (auto& it: ump) {
    if(it.second != 0) {
        return 0;
} 
return 1;

if语句中的条件

if(ump.empty())

不正确。如果传递的数组大小不为零,则映射不能为空。

您可以使用标准算法 std::all_of 而不是条件。也没有意义传递数组的两个大小,因为如果它们彼此不相等,那么很明显数组彼此不相等。

数组参数也应使用限定符 const 指定,因为它们在函数中不会更改。

这是一个演示程序,展示了如何定义函数。

#include <iostream>
#include <iomanip>
#include <unordered_map>
#include <iterator>
#include <algorithm>

bool SameArray( const int a1[], const int a2[], size_t n )
{
    sstd::unordered_map<int, int> m;

    for ( const int *p = a1; p != a1 + n; ++p ) ++m[*p];
    for ( const int *p = a2; p != a2 + n; ++p ) --m[*p];


    return std::all_of( std::begin( m ), std::end( m ), 
                        []( const auto &p) { return p.second == 0; } );
}

int main() 
{
    const size_t N = 20;

    int a1[N] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
    int a2[N] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };

    std::cout << std::boolalpha << SameArray( a1, a2, N ) << '\n';

    return 0;
}

它的输出是

true

ump[arr2[i]]--; 不会删除密钥。您必须检查每个条目的值是否为零。我在 return 1 -

之前添加了以下声明

for (auto it = ump.begin(); it != ump.end(); ++it ) if(it->second != 0) return 0;

int SameArray(int arr1[], int arr2[], int N, int M)
{
    unordered_map<int, int> ump;
    if(N == M)
    {
        for(int i = 0; i < N; i++)
        {
            ump[arr1[i]]++;
        }
        for(int i = 0; i< M; i++)
        {
            if(ump.find(arr2[i]) != ump.end())
                ump[arr2[i]]--;
        }
        for (auto it = ump.begin(); it != ump.end(); ++it ) if(it->second != 0) return 0; 
        return 1;
    }
    return 0;
}