gpt4 book ai didi

c - 使用 C 使用分而治之法查找数组中的多数元素

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:54:50 26 4
gpt4 key购买 nike

我正在编写一个算法来查找数组中的多数元素。基本上,如果一个元素在数组中至少出现 length/2,那么它就是多数元素。否则,该数组没有多数元素。

我不太精通 C,所以我在 Python 中找到了相同的解决方案,并尝试将其转换。但是,我得到的结果有一些不寻常的错误。我的算法是这样的:

#include <stdio.h>
int find_majority_element(int arr[], int length);

int main()
{
int arr[] = { 12, 3, 1, 1, 3, 4, 2, 2, 9, 6, 2, 1, 2 };
int length = sizeof(arr)/sizeof(int);

int result = find_majority_element(arr, length);

if (result == -1) {
printf("None");
} else {
printf("%d", result);
}
return 0;
}

int find_majority_element(int arr[], int length) {

if (length == 2) {
if (arr[0] == arr[1]) {
return arr[0];
} else {
return -1;
}
} else if (length == 1) {
return arr[0];
}

int *leftHalf = arr;
int *rightHalf = arr + length/2;

int element1 = find_majority_element(leftHalf, length/2);
int element2 = find_majority_element(rightHalf, length/2);

if (element1 == -1 && element2 >= 0) {
return element2;
} else if (element2 == -1 && element1 >= 0) {
return element1;
}

if (element1 == element2) {
return element1;
} else {
return -1;
}

}

这给了我意想不到的结果,考虑到我刚刚转换了另一种算法,这很奇怪。有问题的算法可以在这里找到:

Link

有什么帮助吗?谢谢。

编辑

对于给定的输入,多数元素显示为 2。这显然是错误的。

最佳答案

length 时,代码没有检查整个右半部分很奇怪。 @jdehesa

// int element2 = find_majority_element(rightHalf, length/2);
int element2 = find_majority_element(rightHalf, length - length/2);

总体而言,OP 的方法对于未排序 数组是不正确的 @Dagan .评论Majority Element用于替代解决方案。


迂腐的角落:代码有问题 length <= 0 .

关于c - 使用 C 使用分而治之法查找数组中的多数元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48987778/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com