所以我得到了这个数组: int arr[] = {60,70,30,15,17,80,16,75,90,85,40,75};
我必须在这个数组中“适应”尽可能多的元素,同时它们的总和小于 500(基本上删除最大的元素,直到总和小于 500)。
这是我尝试过的:
#include <iostream>
#include <algorithm>
#include <list>
using namespace std;
int largestOfArray(int number[]);
int main()
{
int sum = 0;
int i = 0;
int arr[] = {60,70,30,15,17,80,16,75,90,85,40,75};
list<int> ar(arr,arr+12);
for (i = 0; i < 12;i++)
sum += arr[i];
while (sum > 500)
ar.remove(largestOfArray(arr[12]));
for (i = 0; i < 12;i++)
sum += arr[i];
for (i = 0;i < 12; i++)
cout << arr[i];
cout << sum;
return 0;
}
int largestOfArray(int number[12]){
int i = 0;
int largest = number[0];
for (i = 0;i < 12;i++){
if (largest < number[i]) largest = number[i];
}
return largest;
}
我不断收到此错误:
‘operator[]’ 不匹配(操作数类型为 ‘std::__cxx11::list’ 和 ‘int’)
我知道它与 ar.remove(largestOfArray(ar[12]));
,但我不知道如何解决它。
原文由 Alpha 发布,翻译遵循 CC BY-SA 4.0 许可协议
首先,您同时使用
ar
和arr
,而arr
是一个数组,而ar
是一个列表。这让读者和(事实证明)代码作者都感到困惑。在 C++ 中,std::list 没有随机访问。您不能使用
ar[]
,因为没有为列表定义 operator[]。此外,largestOfArray
需要一个数组,而不是一个列表。您可能打算在那里使用arr
而不是ar
。