作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在编写一个算法来查找数组中的多数元素。基本上,如果一个元素在数组中至少出现 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;
}
}
这给了我意想不到的结果,考虑到我刚刚转换了另一种算法,这很奇怪。有问题的算法可以在这里找到:
有什么帮助吗?谢谢。
编辑
对于给定的输入,多数元素显示为 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/
我是一名优秀的程序员,十分优秀!