而不是打字
array[0] + array[1] //.....(and so on)
有没有办法将数组中的所有数字相加?我正在使用的语言是c ++我希望能够以更少的输入来完成它,而不是我刚输入的语言。
试试这个:
int array[] = {3, 2, 1, 4};
int sum = 0;
for (int i = 0; i < 4; i++) {
sum = sum + array[i];
}
std::cout << sum << std::endl;
以下是在C ++中执行此操作的惯用方法:
int a[] = {1, 3, 5, 7, 9};
int total = accumulate(begin(a), end(a), 0, plus<int>());
说你有一个int array[N]
。
你可以简单地做:
int sum = 0;
for(auto& num : array)
sum += num;
如果你使用valarray
,那就有一个成员函数sum()
。
#include <iostream> // std::cout
#include <valarray> // std::valarray
int main () {
std::valarray<int> myvalarray(4);
myvalarray[0] = 0;
myvalarray[1] = 10;
myvalarray[2] = 20;
myvalarray[3] = 30;
std::cout << "The sum is " << myvalarray.sum() << '\n';
return 0;
}
我能看到的最简单方法是使用循环。奖励是你可以在任何整数数组上使用它而不需要重写很多代码。我更频繁地使用Java,所以我希望没有太多的语法错误,但是这样的事情应该有效:
int addArray(int[] array, int length){
int sum=0;
for(int count=0;count<length;count++){
sum+=array[count];
}
return sum;
}
在C ++ 17中,可以使用折叠表达式:
template<typename ...Ts>
int sum_impl(Ts&& ...a)
{
return (a + ...);
}
如果sum_impl
有一个恒定数量的参数,我们可以像这样调用它:
std::apply(sum_impl, arr);
假设arr是std::array<int, N>
。但由于它是可变的,它需要一点助手:
using namespace std;
template <class Array, size_t... I>
int sum_impl(Array&& a, index_sequence<I...>)
{
return sum_impl(get<I>(forward<Array>(a))...);
}
template <class Array>
int sum(Array&& a)
{
return sum_impl(forward<Array>(a),
make_index_sequence<tuple_size_v<decay_t<Array>>>{});
}
因此,假设这些帮助程序到位,代码将如下所示:
template<typename ...Ts>
int sum_impl(Ts&& ...a)
{
return (a + ...);
}
int main()
{
array<int, 10> arr{0,1,2,3,4,5,6,7,8,9};
cout << sum(arr) << "\n";
return 0;
}
我们可以使用用户定义的函数。
代码片段:
#include<bits/stdc++.h>
using namespace std;
int sum(int arr[], int n)
{
int sum=0;
for(int i=0; i<n; i++)
{
sum += arr[i];
}
return sum;
}
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = distance(begin(arr), end(arr));
int total = sum(arr,n);
printf("%d", total);
return 0;
}
int Sum;
for(int& S: List) Sum += S;