Sum of Array: Difference between revisions

From Rosetta Code
Content deleted Content added
mNo edit summary
m fixed redirect since multiple redirects aren't followed
 
(40 intermediate revisions by 18 users not shown)
Line 1: Line 1:
#REDIRECT [[Sum and product of an array]]
[http://nibko.info/data/un-altro.htm un altro colore per il game boy advance] [http://hangzhau.cn/html/l-aspo/ l aspo srl] [http://puli.org.cn/web/majestic-lcd/ majestic lcd] [http://puli.org.cn/web/sborrate-trans/ sborrate trans] [http://puli.org.cn/web/herpes-flares/ herpes flares] [http://hangzhau.cn/html/viaggi-budapest/ viaggi budapest] [http://puli.org.cn/web/repuplica/ repuplica] [http://zodip.info/description/cd-philips.htm cd philips tavolo] [http://nibko.info/data/volume-muscolare.htm volume muscolare integratori] [http://puli.org.cn/web/km-lancia/ km0 lancia diesel auto km 0] [http://puli.org.cn/web/diario-on/ diario on line] [http://italnet.net.cn/img/dragon-ballz/ dragon ballz] [http://italnet.net.cn/img/scene-da/ scene da un matrimonio] [http://puli.org.cn/web/ligerie/ ligerie] [http://italnet.net.cn/img/biliardo-carambola/ biliardo carambola] [http://hangzhau.cn/html/gps-palmare/ gps palmare gprs gsm] [http://hangzhau.cn/html/solo-scarpe/ solo scarpe puma] [http://hangzhau.cn/html/micro-hifi/ micro hi-fi usb] [http://italnet.net.cn/img/rendy/ rendy] [http://zodip.info/description/trans-sex.htm trans sex movie] [http://zodip.info/description/ambro-consalting.htm ambro consalting] [http://hangzhau.cn/html/dvdshrink/ dvdshrink] [http://zodip.info/description/new-keys.htm new keys arabesque] [http://nibko.info/data/usb-ide.htm usb ide] [http://puli.org.cn/web/leonardo-dicaprio/ leonardo dicaprio] [http://italnet.net.cn/img/hoover-tc/ hoover tc3866] [http://italnet.net.cn/img/esse-music/ esse music treviso] [http://zodip.info/description/una-breve.htm una breve stagione] [http://zodip.info/description/nvidia-geforce.htm nvidia geforce 6200 256 mb] [http://zodip.info/description/premiere.htm premiere 6 5] [http://nibko.info/data/linksys-amplificatore.htm linksys amplificatore wireless] [http://zodip.info/description/casino-lights.htm casino lights 99. live at the montreux jazz festival 1999] [http://nibko.info/data/cd-dennis.htm cd dennis] [http://hangzhau.cn/html/nikon-sb/ nikon sb600] [http://puli.org.cn/web/occhiali-rosa/ occhiali rosa] [http://puli.org.cn/web/refill-inchiostro/ refill inchiostro] [http://hangzhau.cn/html/giochi-erotici/ giochi erotici] [http://zodip.info/description/james-last.htm james last end his orchestra] [http://nibko.info/data/indirizzi-parrocchie.htm indirizzi parrocchie] [http://nibko.info/data/x.htm x 20] [http://italnet.net.cn/img/www-pene/ www pene] [http://hangzhau.cn/html/televisori-al/ televisori al plasma phocus 42] [http://zodip.info/description/testo-anastacia.htm testo anastacia] [http://nibko.info/data/verbatim-hi.htm verbatim hi speed 512 mb] [http://hangzhau.cn/html/roger-sanchez/ roger sanchez] [http://hangzhau.cn/html/vip-in/ vip in perizoma] [http://zodip.info/description/moriconi.htm moriconi] [http://italnet.net.cn/img/konus-telescopi/ konus telescopi] [http://puli.org.cn/web/missione-eroica/ missione eroica - pompieri 2] [http://puli.org.cn/web/pyro-maniac/ pyro maniac] [http://hangzhau.cn/html/mp-kenwood/ mp3 kenwood lettori] [http://hangzhau.cn/html/bubblin-blue/ bubblin blue] [http://hangzhau.cn/html/peg-/ peg - pliko p3] [http://italnet.net.cn/img/cluedo-live/ cluedo live] [http://nibko.info/data/red-castle.htm red castle] [http://puli.org.cn/web/legends-rochi/ legends rochi] [http://italnet.net.cn/img/pnp/ pnp] [http://puli.org.cn/web/carolina-gf/ carolina gf] [http://hangzhau.cn/html/concerto-robbie/ concerto robbie williams] [http://nibko.info/data/oakley-sweep.htm oakley sweep] [http://zodip.info/description/banda-calypso.htm banda calypso ao vivo] [http://hangzhau.cn/html/policitemia/ policitemia] [http://zodip.info/description/chistes-para.htm chistes para bajar gratis] [http://hangzhau.cn/html/wharfedale-/ wharfedale 9 2 diamond] [http://zodip.info/description/bane-buski.htm bane buski] [http://italnet.net.cn/img/carrozza-di/ carrozza di barbie] [http://puli.org.cn/web/stanza-/ stanza 3 sesso] [http://zodip.info/description/www-mirabilandia.htm www mirabilandia it] [http://zodip.info/description/la-donna.htm la donna del traditore] [http://puli.org.cn/web/connessione-internet/ connessione internet flat] [http://italnet.net.cn/img/bebe-confort/ bebe confort camelia] [http://zodip.info/description/granchi.htm granchi] [http://hangzhau.cn/html/verbatim-crystal/ verbatim crystal super azo] [http://hangzhau.cn/html/atlantis-isdn/ atlantis isdn pci] [http://italnet.net.cn/img/amplificatori-akai/ amplificatori akai] [http://zodip.info/description/ezzolied.htm ezzolied] [http://zodip.info/description/pvra-mustek.htm pvr-a1 mustek] [http://hangzhau.cn/html/trayler/ trayler] [http://puli.org.cn/web/testo-di/ testo di mi manchi da morire] [http://hangzhau.cn/html/videoannunci-amatoriali/ videoannunci amatoriali] [http://hangzhau.cn/html/giochino/ giochino] [http://puli.org.cn/web/produttori-bicicletta/ produttori bicicletta] [http://puli.org.cn/web/mp-smacdown/ mp3 smacdown] [http://italnet.net.cn/img/bravo/ bravo] [http://zodip.info/description/climatizzatore-.htm climatizzatore 9000 btu] [http://puli.org.cn/web/vacanze-sangue/ vacanze sangue] [http://hangzhau.cn/html/muf/ muf] [http://italnet.net.cn/img/ciao-amico/ ciao amico ciao ciao ciao] [http://nibko.info/data/addiction-puzzle.htm addiction puzzle] [http://nibko.info/data/beautiful-soundtrack.htm beautiful soundtrack] [http://hangzhau.cn/html/bk-take/ b2k take it to the floor] [http://puli.org.cn/web/calzature-moda/ calzature moda] [http://hangzhau.cn/html/delonghi-condizionatore/ delonghi condizionatore pac] [http://zodip.info/description/verbatim-cdr.htm verbatim cdr] [http://italnet.net.cn/img/ferro-stiro/ ferro stiro rowenta] [http://zodip.info/description/gelada.htm gelada] [http://hangzhau.cn/html/mangiameli-stelio/ mangiameli stelio] [http://hangzhau.cn/html/webcam-live/ webcam live pro] [http://italnet.net.cn/img/viaggi-crociere/ viaggi crociere] [http://nibko.info/data/pc-gamepad.htm pc gamepad force vibration usb] [http://puli.org.cn/web/tea/ tea] [http://puli.org.cn/web/kingston-gb/ kingston 2gb compact flash] [http://puli.org.cn/web/kartell-arredamento/ kartell arredamento] [http://zodip.info/description/dvdrw-usb.htm dvd-rw usb esterno] [http://zodip.info/description/canon-ef.htm canon ef 24-85mm f 3 5-4 5 usm] [http://hangzhau.cn/html/ocz-alimentatore/ ocz alimentatore] [http://hangzhau.cn/html/plotter-a/ plotter a1 colori] [http://hangzhau.cn/html/time-kid/ time kid la macchina] [http://hangzhau.cn/html/aspirapolvere-vapore/ aspirapolvere vapore con filtro ad acqua] [http://hangzhau.cn/html/la-duchessa/ la duchessa di santa lucia] [http://puli.org.cn/web/ragazzo-carino/ ragazzo carino luca] [http://italnet.net.cn/img/comap/ comap] [http://italnet.net.cn/img/mlt-g/ ml370t g4] [http://puli.org.cn/web/conizzazione/ conizzazione] [http://puli.org.cn/web/toons-porn/ toons porn] [http://zodip.info/description/carola-end.htm carola end tommy] [http://hangzhau.cn/html/nude-calde/ nude, calde e pure] [http://italnet.net.cn/img/live-for/ live for today] [http://hangzhau.cn/html/letterina/ letterina] [http://hangzhau.cn/html/egitto-mappa/ egitto mappa] [http://hangzhau.cn/html/infocus-dlp/ infocus dlp] [http://hangzhau.cn/html/camion-da/ camion da rally] [http://hangzhau.cn/html/integratori-per/ integratori per lo sport] [http://puli.org.cn/web/monitor-con/ monitor con box] [http://italnet.net.cn/img/gf-/ gf 6200 256 mb] [http://italnet.net.cn/img/mondiali-di/ mondiali di ciclismo] [http://nibko.info/data/penis-enlargement.htm penis enlargement] [http://italnet.net.cn/img/playstation-/ playstation 2 fighting jam] [http://hangzhau.cn/html/decapitazione-ostaggio/ decapitazione ostaggio turco] [http://hangzhau.cn/html/testi-canzoni/ testi canzoni vasco rossi ti voglio be] [http://puli.org.cn/web/craigdavid/ craigdavid] [http://zodip.info/description/magic-system.htm magic system mohamed lamine] [http://nibko.info/data/gli-eroi.htm gli eroi del deserto] [http://puli.org.cn/web/software-windows/ software windows xp] [http://puli.org.cn/web/lecce/ lecce] [http://zodip.info/description/this-is.htm this is the world alcazar] [http://puli.org.cn/web/lettori-xvid/ lettori xvid amstrad] [http://nibko.info/data/primo-aggiornamento.htm primo aggiornamento per lineage ii] [http://nibko.info/data/video-usa.htm video usa decapitato] [http://puli.org.cn/web/dsch/ dsc-h1] [http://puli.org.cn/web/kia-sorento/ kia sorento] [http://zodip.info/description/assistenza-teramo.htm assistenza teramo] [http://hangzhau.cn/html/il-signore/ il signore degli anelli extended version] [http://hangzhau.cn/html/troni/ troni] [http://nibko.info/data/garnet.htm garnet] [http://hangzhau.cn/html/ricorso-al/ ricorso al prefetto] [http://zodip.info/description/wwww-porta.htm wwww porta net] [http://puli.org.cn/web/gwen-stefany/ gwen stefany what you waiting for] [http://italnet.net.cn/img/doppia-sim/ doppia sim nokia 3100] [http://puli.org.cn/web/tette-da/ tette da latte] [http://zodip.info/description/logitech.htm logitech 230] [http://puli.org.cn/web/immagini-delle/ immagini delle sorelle olsen] [http://zodip.info/description/polti-super.htm polti super pro] [http://puli.org.cn/web/steet-to/ steet to hell] [http://hangzhau.cn/html/eva-robin/ eva robin s] [http://italnet.net.cn/img/supporto-ventosa/ supporto ventosa] [http://hangzhau.cn/html/geli-d/ geli d mora] [http://nibko.info/data/abbigliamento-donna.htm abbigliamento donna elegante] [http://italnet.net.cn/img/glivec/ glivec] [http://hangzhau.cn/html/www-irene/ www irene grandi com] [http://italnet.net.cn/img/i-prodotti/ i prodotti di 4 e 5 gamma] [http://nibko.info/data/calcolo-ici.htm calcolo ici 2004 roma] [http://zodip.info/description/toshiba-palmari.htm toshiba palmari e800] [http://nibko.info/data/naturismo-spagna.htm naturismo spagna] [http://zodip.info/description/impronte-animali.htm impronte animali] [http://italnet.net.cn/img/del-pit/ del pit pita del] [http://italnet.net.cn/img/castrocaro-terme/ castrocaro terme] [http://zodip.info/description/sito-astrologia.htm sito astrologia] [http://zodip.info/description/lcd-da.htm lcd da 20] [http://puli.org.cn/web/burundanga/ burundanga] [http://puli.org.cn/web/gucci-dress/ gucci dress] [http://zodip.info/description/scheda-madre.htm scheda madre wifi] [http://puli.org.cn/web/gena-lee/ gena lee nolan sex] [http://zodip.info/description/mogli-russi.htm mogli russi nude] [http://nibko.info/data/www-carlino.htm www carlino it] [http://italnet.net.cn/img/bejewlled/ bejewlled] [http://hangzhau.cn/html/frigorifero-/ frigorifero 160 cm] [http://hangzhau.cn/html/levico/ levico] [http://zodip.info/description/cart.htm cart] [http://nibko.info/data/mercedes-classe.htm mercedes classe c 220] [http://italnet.net.cn/img/lettorimp-samsung/ lettorimp3 samsung] [http://puli.org.cn/web/cosa-sono/ cosa sono le nuvole] [http://italnet.net.cn/img/crane-hart/ crane, hart] [http://zodip.info/description/dildi.htm dildi] [http://puli.org.cn/web/eukanuba-cani/ eukanuba cani] [http://hangzhau.cn/html/maria-kerry/ maria kerry] [http://hangzhau.cn/html/chefs-help/ chefs help] [http://zodip.info/description/panasonic-dvd.htm panasonic dvd] [http://puli.org.cn/web/hoover-h/ hoover h 3360] [http://puli.org.cn/web/numeri-per/ numeri per sesso] [http://italnet.net.cn/img/vacanze-in/ vacanze in agosto] [http://zodip.info/description/bello-e.htm bello e impossibile] [http://italnet.net.cn/img/concessionarie-abruzzo/ concessionarie abruzzo] [http://italnet.net.cn/img/canzone-midi/ canzone midi] [http://italnet.net.cn/img/sain-seiya/ sain seiya] [http://italnet.net.cn/img/yet-look/ yet look what you have done] [http://zodip.info/description/porcellana-ceramica.htm porcellana ceramica altra arredamento] [http://nibko.info/data/garde.htm garde] [http://zodip.info/description/ednita-nazario.htm ednita nazario] [http://nibko.info/data/the-cramberris.htm the cramberris] {{task}}
Compute the sum of the elements of an Array

==[[4D]]==
[[Category:4D]]

ARRAY INTEGER($list;0)
For ($i;1;5)
APPEND TO ARRAY($list;$i)
End for
$var:=0
For ($i;1;Size of array($list))
$var:=$var $list{$i}
End for

==[[Ada]]==
[[Category:Ada]]

Int_Array : array(1..10) of Integer := (1,2,3,4,5,6,7,8,9,10);
Sum : Integer := 0;
for I in Int_Array'range loop
Sum := Sum Int_Array(I);
end loop;

==[[AppleScript]]==
[[Category:AppleScript]]

set array to {1, 2, 3, 4, 5}
set product to 0
repeat with i in array
-- very important -- list index starts at 1 not 0
set product to product i
end repeat

==[[BASIC]]==
[[Category:BASIC]]

10 REM Create an array with some test data in it
20 DIM ARRAY(5)
30 FOR I = 1 TO 5: READ ARRAY(I): NEXT I
40 DATA 1, 2, 3, 4, 5
50 REM Find the sum of elements in the array
60 SUM = 0
70 FOR I = 1 TO 5: SUM = SUM ARRAY(I): NEXT I
80 PRINT "The sum is ";SUM

==[[C plus plus|C ]]==
[[Category:C plus plus]]

'''Compiler:''' [[GNU Compiler Collection|gcc]] 4.0.2

int
main( int argc, char* argv[] )
{
int list[] = { 1, 2, 3 } ;
int sum = 0 ;
for( int i = 0 ; i < 3 ; i )
{
sum = list[i];
}
}


Alternate

#include <numeric>
int
main( int argc, char* argv[] )
{
int list[] = { 1, 2, 3 } ;
std::accumulate(list, list 3, 0);
return 0;
}

template alternative

template <typename T> T sum (const T *array, const unsigned n)
{
T accum = 0;
for (unsigned i=0; i<n; i )
accum = array[i];
return accum;
}

#include <iostream>
using std::cout;
using std::endl;

int main (void)
{
int aint[] = {1, 2, 3};
cout << sum(aint,3) << endl;
float aflo[] = {1.1, 2.02, 3.003, 4.0004};
cout << sum(aflo,4) << endl;
return 0;
}

==[[C sharp|C#]]==
[[Category:C sharp|C#]]

int value = 0;
int[] arg = { 1,2,3,4,5 };
int arg_length = arg.Length;

for( int i = 0; i < arg_length; i )
value = arg[i];


Alternate

int sum = 0;
int[] arg = { 1, 2, 3, 4, 5 };
foreach (int value in arg) sum = value;

==[[Clean]]==
[[Category:Clean]]
array = {1, 2, 3, 4, 5}
Start = sum [x \\ x <-: array]

==[[ColdFusion]]==
[[Category:ColdFusion]]

<cfset myArray = listToArray("1,2,3,4,5")>
#arraySum(myArray)#

==[[Common Lisp]]==
[[Category:Common Lisp]]

(defparameter *data* #(1 2 3 4 5))
(reduce #' *data*)

==[[Delphi]]==
[[Category:Delphi]

'''Compiler:''' [[All]]

var
Ints : array[1..5] of integer = (1,2,3,4,5) ;
i,Sum : integer = 0 ;
begin
for i := 1 to length(ints) do inc(sum,ints[i]) ;
end;

==[[E]]==
[[Category:E]]

pragma.enable("accumulator")
accum 0 for x in [1,2,3,4,5] { _ x }

==[[Erlang]]==
[[Category:Erlang]]

Using the standard libraries:

% create the list:
L = lists:seq(1, 10).

% and compute its sum:
S = lists:sum(L).

Or defining our own versions:

-module(list_sum).
-export([sum_rec/1, sum_tail/1]).

% recursive definition:
sum_rec([]) ->
0;
sum_rec([Head|Tail]) ->
Head sum_rec(Tail).

% tail-recursive definition:
sum_tail(L) ->
sum_tail(L, 0).
sum_tail([], Acc) ->
Acc;
sum_tail([Head|Tail], Acc) ->
sum_tail(Tail, Head Acc).

==[[Forth]]==
[[Category:Forth]]

: sum ( addr cnt -- n )
0 -rot
cells bounds do i @ cell loop ;


==[[FreeBASIC]]==
[[Category:FreeBASIC]]

dim array(4) as integer = { 1, 2, 3, 4, 5 }

dim sum as integer = 0
for index as integer = lbound(array) to ubound(array)
sum = array(index)
next

==[[Haskell]]==
[[Category:Haskell]]

let values = [1..10]
sum values -- the easy way
foldl ( ) 0 values -- the hard way

==[[IDL]]==
[[Category:IDL]]

result = total(array)

==[[Java]]==
[[Category:Java]]

int value = 0;
int[] arg = new int[] { 1,2,3,4,5 };
for (int i: arg)
value = i;

==[[JavaScript]]==
[[Category:JavaScript]]

var array = [1, 2, 3, 4, 5];
var sum = 0;
for(var i in array)
sum = array[i];

==[[Perl]]==
[[Category:Perl]]

'''Interpeter:''' [[Perl]]
my $var;
my @list = (1, 2, 3);
$var = $_ for (@list);

Alternate

'''Libraries:''' List::Util

use List::Util 'sum';
my @list = (1, 2, 3);
my $var = sum @list;

Alternate

'''# TMTOWTDI'''
my $acc = 0;
my @list = qw(1 2 3)
map { $acc = $_ } @list

==[[PHP]]==
[[Category:PHP]]

$list = array(1,2,3,4,5,6,7,8,9);
echo array_sum($list);

==[[Pop11]]==
[[Category:Pop11]]

Simple loop:

lvars i, sum = 0, ar = {1 2 3 4 5 6 7 8 9};
for i from 1 to length(ar) do
ar(i) sum -> sum;
endfor;

One can alternativly use second order iterator:

lvars sum = 0, ar = {1 2 3 4 5 6 7 8 9};
appdata(ar, procedure(x); x sum -> sum; endprocedure);

==[[Prolog]]==
[[Category:Prolog]]
sum([],0).
sum([H|T],X) :- sum(T,Y), X is H Y.
test
:- sum([1,2,3,4,5,6,7,8,9],X).
X =45;

==[[Python]]==
[[Category:Python]]

'''Interpeter:''' [[Python]] 2.5
total = sum([1, 2, 3, 4, 5, 6, 7, 8, 9])

==[[Ruby]]==
[[Category:Ruby]]

ary = [1,2,3,4,5]
sum = ary.inject{|currentSum,element|currentSum element}
# => 15

== [[Scala]]==
[[Category:Scala]]
val array = Array(1,2,3,4,5)
val sum = array.foldLeft(0)(_ _)

This is a shortcut for
val sum = array.foldLeft(0){(currentSum, element) => currentSum element}

==[[Seed7]]==
[[Category:Seed7]]

const func integer: sumArray (in array integer: valueArray) is func
result
var integer: sum is 0;
local
var integer: value is 0;
begin
for value range valueArray do
sum := value;
end for;
end func;

Call this function with:

writeln(sumArray([](1, 2, 3, 4, 5)));

==[[Standard ML]]==
[[Category:Standard ML]]

val array = [1,2,3,4,5];
foldl op 0 array;

==[[Tcl]]==
[[Category:Tcl]]

Assuming the values are in a list named <tt>listname</tt>:

set result [expr [join $listname ]]

==[[Toka]]==
[[Category:Toka]]

[ ( array size -- sum )
>r 0 r> [ over i swap get-element ] iterate nip ] is sum-array

==[[UNIX Shell]]==
[[Category:UNIX Shell]]

'''Interpreter:''' NetBSD 3.0's ash

From an internal variable, $IFS delimited:

sum=0
list="1 2 3"
for n in $list
do sum="$(($sum $n))"
done
echo $sum

From the argument list (ARGV):

sum=0
for n
do sum="$(($sum $n))"
done
echo $sum

From STDIN, one integer per line:

sum=0
while read n
do sum="$(($sum $n))"
done
echo $sum

'''Interpreter:''' GNU bash, version 3.2.0(1)-release (i386-unknown-freebsd6.1)

From variable:

LIST='20 20 2';
SUM=0;
for i in $LIST; do
SUM=$[$SUM $i];
done;
echo $SUM

Latest revision as of 08:39, 2 July 2010