Au lieu de taper
array[0] + array[1] //.....(and so on)
existe-t-il un moyen d’additionner tous les nombres d’un tableau? Le langage que j'utilise serait le c ++ Je veux pouvoir le faire avec moins de dactylographie que si je le tapais tout seul.
Essaye ça:
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;
Voici la manière idiomatique de faire cela en C++:
int a[] = {1, 3, 5, 7, 9};
int total = accumulate(begin(a), end(a), 0, plus<int>());
Disons que vous avez un int array[N]
.
Vous pouvez simplement faire:
int sum = 0;
for(auto& num : array)
sum += num;
Si vous utilisez une valarray
, il existe une fonction membre sum()
pour cela.
#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;
}
Le moyen le plus simple de procéder consiste à utiliser une boucle. Le bonus est que vous pouvez l'utiliser sur n'importe quel tableau d'entiers sans avoir à réécrire beaucoup de code. J'utilise Java plus souvent, j'espère donc qu'il n'y aura pas trop d'erreurs de syntaxe, mais quelque chose comme cela devrait fonctionner:
int addArray(int[] array, int length){
int sum=0;
for(int count=0;count<length;count++){
sum+=array[count];
}
return sum;
}
En C++ 17, on pourrait utiliser des expressions fold:
template<typename ...Ts>
int sum_impl(Ts&& ...a)
{
return (a + ...);
}
Si sum_impl
avait un nombre constant de paramètres, nous aurions pu l'appeler ainsi:
std::apply(sum_impl, arr);
en supposant que arr est std::array<int, N>
. Mais comme il est variadique, il faut un peu de Push avec les assistants:
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>>>{});
}
Par conséquent, en supposant que ces aides soient en place, le code ressemblera à ceci:
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;
}
Nous pouvons utiliser une fonction définie par l'utilisateur.
Extrait de code :
#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;
}