Sum of Array: Difference between revisions

From Rosetta Code
Content added Content deleted
mNo edit summary
(revert spam)
Line 1: Line 1:
{{task}}
[http://spirit-psyki.ifrance.com/lib/fly-girls.html fly girls] [http://tulip123456.ifrance.com/topic/diana-spencer.html diana spencer nuda] [http://doctorpinkerton.ifrance.com/lib/giochi-erotico/ giochi erotico on line gratis] [http://elixirium.ifrance.com/lib/annunci-incontri.html annunci incontri lesbo] [http://bakadeshi.ifrance.com/img/styles/ragazze-la.html ragazze la spezia] [http://adrienneee.ifrance.com/blog/carolina-desnuda/ carolina desnuda su visto] [http://jnk713.ifrance.com/img/styles/porno-maturo/ porno maturo vecchie troie] [http://bakadeshi.ifrance.com/img/styles/upmini-nudi.html upmini nudi] [http://end14april.ifrance.com/blog/email-per.html email per sesso] [http://elixirium.ifrance.com/lib/www-xxx.html www xxx18 com] [http://furrysoap.ifrance.com/videoclip-sesso/ videoclip sesso] [http://cincydj.ifrance.com/images/small/foto-di/ foto di vale rossi nudo] [http://tulip123456.ifrance.com/topic/viduo-sex.html viduo sex] [http://tulip123456.ifrance.com/topic/gessica-rizzo.html gessica rizzo pornodiva] [http://tulip123456.ifrance.com/topic/nonna-incesto.html nonna incesto] [http://competitio.ifrance.com/numeri-di/ numeri di telefono di ragazze porche] [http://mi-kkiechang.ifrance.com/foto-porno.html foto porno di mature] [http://mi-kkiechang.ifrance.com/le-ragazze.html le ragazze del porno show] [http://mi-kkiechang.ifrance.com/george-michel.html george michel] [http://end14april.ifrance.com/blog/quando-le.html quando le donne si chiamavano madonne] [http://spirit-psyki.ifrance.com/lib/tuttogratis-it.html tuttogratis it] [http://doctorpinkerton.ifrance.com/lib/playboy-giugno/ playboy giugno] [http://tulip123456.ifrance.com/topic/porno-ilaria.html porno ilaria damico] [http://end14april.ifrance.com/blog/gay-varese.html gay varese] [http://bakadeshi.ifrance.com/img/styles/video-manga.html video manga gratis] [http://tulip123456.ifrance.com/topic/video-gratis.html video gratis de michell vieth] [http://spirit-psyki.ifrance.com/lib/video-animali.html video animali porno] [http://adrienneee.ifrance.com/blog/foto-di/ foto di nudisti in spiaggia] [http://doctorpinkerton.ifrance.com/lib/eros-ramazzotti/ eros ramazzotti dvd roma] [http://tulip123456.ifrance.com/topic/image-sex.html image sex] [http://adrienneee.ifrance.com/blog/analisi-del/ analisi del tessuto urbano di matera] [http://tulip123456.ifrance.com/topic/sexy-sasha.html sexy sasha] [http://cincydj.ifrance.com/images/small/otto-donne/ otto donne e mezzo] [http://doctorpinkerton.ifrance.com/lib/corelli-audio/ corelli audio analogue] [http://end14april.ifrance.com/blog/donne-puttane.html donne puttane] [http://mi-kkiechang.ifrance.com/george-micheal.html george micheal faith] [http://tulip123456.ifrance.com/topic/foto-donne.html foto donne perizoma] [http://elixirium.ifrance.com/lib/free-animalsex.html free animalsex] [http://bakadeshi.ifrance.com/img/styles/donne-sesso.html donne sesso cercasi] [http://elixirium.ifrance.com/lib/vagina-di.html vagina di pamela anerson] [http://adrienneee.ifrance.com/blog/naked-souls/ naked souls] [http://tulip123456.ifrance.com/topic/sexy-gallery.html sexy gallery] [http://competitio.ifrance.com/donna-per/ donna per sesso con numero di cellulare visibile] [http://elixirium.ifrance.com/lib/porno-video.html porno video gay italiani] [http://mi-kkiechang.ifrance.com/racconti-sculacciate.html racconti sculacciate gratis] [http://spirit-psyki.ifrance.com/lib/japan-sesso.html japan sesso] [http://mi-kkiechang.ifrance.com/video-sesso.html video sesso con animali] [http://end14april.ifrance.com/blog/supergirl-.html supergirl - la ragazza dacciaio] [http://adrienneee.ifrance.com/blog/porno-infanti/ porno infanti fotos] [http://adrienneee.ifrance.com/blog/snakesandladders/ snakesandladders] [http://elixirium.ifrance.com/lib/ballerine-sexy.html ballerine sexy] [http://elixirium.ifrance.com/lib/porno-di.html porno di gruppo gratuito] [http://end14april.ifrance.com/blog/testi-canzoni.html testi canzoni gratis] [http://adrienneee.ifrance.com/blog/paola-y/ paola y chiara] [http://elixirium.ifrance.com/lib/chat-sex.html chat sex] [http://tulip123456.ifrance.com/topic/porno-amatoriali.html porno amatoriali gratis] [http://doctorpinkerton.ifrance.com/lib/juegosgratis/ juegosgratis] [http://elixirium.ifrance.com/lib/incinte-porno.html incinte porno] [http://end14april.ifrance.com/blog/gabriel-pontello.html gabriel pontello supersex] [http://competitio.ifrance.com/video-porno/ video porno di pam e tommy] [http://elixirium.ifrance.com/lib/video-pamela.html video pamela anderson con marito] [http://furrysoap.ifrance.com/fotoannunci-erotici/ fotoannunci erotici] [http://furrysoap.ifrance.com/rita-montella/ rita montella sexy] [http://mi-kkiechang.ifrance.com/donne-mature.html donne mature cercano] [http://furrysoap.ifrance.com/penetrazioni-anali/ penetrazioni anali] [http://adrienneee.ifrance.com/blog/cine-sex/ cine sex] [http://mi-kkiechang.ifrance.com/peliculas-pornos.html peliculas pornos] [http://competitio.ifrance.com/victor-manuelle/ victor manuelle gratis] [http://adrienneee.ifrance.com/blog/scarica-film/ scarica film porno] [http://adrienneee.ifrance.com/blog/fotos-del/ fotos del video de roxana diaz con jorge] [http://doctorpinkerton.ifrance.com/lib/parkingsex/ parkingsex] [http://doctorpinkerton.ifrance.com/lib/provini-porno/ provini porno] [http://cincydj.ifrance.com/images/small/www-sexpistols/ www sexpistols com] [http://mi-kkiechang.ifrance.com/foto-porno.html foto porno di alessia marcuzzi] [http://mi-kkiechang.ifrance.com/gwen-stefani.html gwen stefani nuda] [http://bakadeshi.ifrance.com/img/styles/veronica-moore.html veronica moore] [http://doctorpinkerton.ifrance.com/lib/file-divertenti/ file divertenti gratis] [http://elixirium.ifrance.com/lib/fatsex.html fatsex] [http://bakadeshi.ifrance.com/img/styles/videos-gratis.html videos gratis de pornos] [http://competitio.ifrance.com/free-gay/ free gay pics] [http://bakadeshi.ifrance.com/img/styles/breatny-spears.html breatny spears nuda] [http://mi-kkiechang.ifrance.com/ragazze-porche.html ragazze porche giovanissime gratis] [http://bakadeshi.ifrance.com/img/styles/porno-donkey.html porno donkey] [http://competitio.ifrance.com/digitale-terrestre/ digitale terrestre tv analogica] [http://spirit-psyki.ifrance.com/lib/www-sexy.html www sexy girls com] [http://jnk713.ifrance.com/img/styles/foto-gay/ foto gay nudi gratis] [http://competitio.ifrance.com/prof-sesso/ prof sesso] [http://adrienneee.ifrance.com/blog/sesso-estremo/ sesso estremo nella figa foto gratis] [http://end14april.ifrance.com/blog/www-sesso.html www sesso sfrenato it] [http://furrysoap.ifrance.com/www-toplessbeach/ www toplessbeach it] [http://mi-kkiechang.ifrance.com/freiras-sexy.html freiras sexy] [http://tulip123456.ifrance.com/topic/chat-adult.html chat adult] [http://bakadeshi.ifrance.com/img/styles/trans-e.html trans e gay che fanno l amore] [http://bakadeshi.ifrance.com/img/styles/racconti-erotici.html racconti erotici adolescenti] [http://elixirium.ifrance.com/lib/lesbian-girls.html lesbian girls photos] [http://spirit-psyki.ifrance.com/lib/sex-animal.html sex animal videoclip] [http://doctorpinkerton.ifrance.com/lib/il-gioco/ il gioco dei nudisti] [http://doctorpinkerton.ifrance.com/lib/ragazze-minigonna/ ragazze minigonna] [http://competitio.ifrance.com/ragazze-a/ ragazze a piedi nudi] [http://furrysoap.ifrance.com/muscoli-gay/ muscoli gay] [http://mi-kkiechang.ifrance.com/severina-sex.html severina sex download free] [http://tulip123456.ifrance.com/topic/sex-appeal.html sex appeal] [http://mi-kkiechang.ifrance.com/porno-zoo.html porno zoo animali] [http://doctorpinkerton.ifrance.com/lib/sex-anal/ sex anal] [http://competitio.ifrance.com/page-perso/ page perso strip xxx photo] [http://bakadeshi.ifrance.com/img/styles/fighe-bagnate.html fighe bagnate gratis] [http://tulip123456.ifrance.com/topic/donne-mature.html donne mature con grosse tette] [http://tulip123456.ifrance.com/topic/assessorato-al.html assessorato al turismo salerno] [http://jnk713.ifrance.com/img/styles/cleopatra-porno/ cleopatra porno] [http://end14april.ifrance.com/blog/lui-e.html lui e il bisex] [http://competitio.ifrance.com/paola-perego/ paola perego foto] [http://tulip123456.ifrance.com/topic/fotoromanzi-porno.html fotoromanzi porno gratuiti] [http://tulip123456.ifrance.com/topic/blue-girl.html blue girl] [http://bakadeshi.ifrance.com/img/styles/testo-italiano.html testo italiano fuck it] [http://doctorpinkerton.ifrance.com/lib/porno-beby/ porno beby] [http://doctorpinkerton.ifrance.com/lib/funny-nuda/ funny nuda] [http://doctorpinkerton.ifrance.com/lib/calendari-di/ calendari di donne] [http://furrysoap.ifrance.com/webcam-amatoriali/ webcam amatoriali porno gratis] [http://competitio.ifrance.com/canalsat-hex/ canalsat hex key] [http://tulip123456.ifrance.com/topic/blaze-of.html blaze of glory gratis] [http://mi-kkiechang.ifrance.com/kyli-minouge.html kyli minouge fotos gratis] [http://competitio.ifrance.com/video-di/ video di sexi ragazze] [http://doctorpinkerton.ifrance.com/lib/sole-nudo/ sole nudo] [http://mi-kkiechang.ifrance.com/bongiorno-paola.html bongiorno paola] [http://cincydj.ifrance.com/images/small/dragonballporno/ dragonballporno] [http://tulip123456.ifrance.com/topic/toscana-sesso.html toscana sesso annunci] [http://spirit-psyki.ifrance.com/lib/nina-sky.html nina sky move your body girl] [http://tulip123456.ifrance.com/topic/foto-donne.html foto donne grasse nere porche] [http://jnk713.ifrance.com/img/styles/donne-e/ donne e dipendenza dal lavoro] [http://doctorpinkerton.ifrance.com/lib/sfondo-canalis/ sfondo canalis] [http://spirit-psyki.ifrance.com/lib/dante-paradiso.html dante paradiso riassunto canto xxxiii] [http://competitio.ifrance.com/www-sex/ www sex culo it] [http://doctorpinkerton.ifrance.com/lib/roxana-diaz/ roxana diaz porno] [http://spirit-psyki.ifrance.com/lib/eros-gratutiti.html eros gratutiti] [http://cincydj.ifrance.com/images/small/go-go/ go go very sexy show] [http://tulip123456.ifrance.com/topic/video-salsa.html video salsa gratis] [http://end14april.ifrance.com/blog/madonna-sexy.html madonna sexy] [http://tulip123456.ifrance.com/topic/sexo-profesional.html sexo profesional] [http://jnk713.ifrance.com/img/styles/baila-sexy/ baila sexy thing] [http://cincydj.ifrance.com/images/small/donne-in/ donne in cerca damore] [http://cincydj.ifrance.com/images/small/foto-transex/ foto transex grtais] [http://adrienneee.ifrance.com/blog/porno-exitantes/ porno exitantes] [http://adrienneee.ifrance.com/blog/vedo-nudo/ vedo nudo] [http://doctorpinkerton.ifrance.com/lib/locali-gay/ locali gay l] [http://mi-kkiechang.ifrance.com/tarzana-sesso.html tarzana sesso selvaggio] [http://end14april.ifrance.com/blog/george-.html george beer] [http://doctorpinkerton.ifrance.com/lib/anziani-gay/ anziani gay foto galleria] [http://bakadeshi.ifrance.com/img/styles/twin-snakes.html twin snakes] [http://doctorpinkerton.ifrance.com/lib/porno-incinte/ porno incinte] [http://mi-kkiechang.ifrance.com/gay-web.html gay web] [http://tulip123456.ifrance.com/topic/foto-gratis.html foto gratis pompini] [http://spirit-psyki.ifrance.com/lib/sessogay.html sessogay] [http://furrysoap.ifrance.com/dyson-edward/ dyson, edward george] [http://tulip123456.ifrance.com/topic/lesbo-stivali.html lesbo stivali] [http://bakadeshi.ifrance.com/img/styles/hentay-sailor.html hentay sailor moon] [http://furrysoap.ifrance.com/lesbo-racconti/ lesbo racconti] [http://competitio.ifrance.com/ipergratis/ ipergratis] [http://end14april.ifrance.com/blog/loghi-sex.html loghi sex] [http://tulip123456.ifrance.com/topic/sesso-forum.html sesso forum] [http://cincydj.ifrance.com/images/small/immagini-transessuali/ immagini transessuali] [http://furrysoap.ifrance.com/japanese-sex/ japanese sex] [http://bakadeshi.ifrance.com/img/styles/foto-di.html foto di donne mature] [http://jnk713.ifrance.com/img/styles/teenager-sesso/ teenager sesso] [http://adrienneee.ifrance.com/blog/girl-fuck/ girl fuck] [http://elixirium.ifrance.com/lib/rollergirl.html rollergirl] [http://furrysoap.ifrance.com/video-gratis/ video gratis de michelle vieth xxx] [http://doctorpinkerton.ifrance.com/lib/le-foto/ le foto sexy di garko] [http://adrienneee.ifrance.com/blog/club-sex/ club sex] [http://mi-kkiechang.ifrance.com/www-paolaechiara.html www paolaechiara] [http://elixirium.ifrance.com/lib/britney-spears.html britney spears xxx] [http://adrienneee.ifrance.com/blog/nudoty/ nudoty] [http://competitio.ifrance.com/famiglia-incestuosa/ famiglia incestuosa] [http://spirit-psyki.ifrance.com/lib/immagini-tettone.html immagini tettone gratis] [http://adrienneee.ifrance.com/blog/sex-termometer/ sex termometer] [http://elixirium.ifrance.com/lib/haiduci-xxx.html haiduci xxx] [http://end14april.ifrance.com/blog/fontana-canalis.html fontana canalis] [http://adrienneee.ifrance.com/blog/show-girl/ show girl croata] [http://jnk713.ifrance.com/img/styles/experimento-caseros/ experimento caseros] [http://cincydj.ifrance.com/images/small/videos-de/ videos de porno] [http://elixirium.ifrance.com/lib/saudi-sesso.html saudi sesso] [http://mi-kkiechang.ifrance.com/eva-robinson.html eva robinson nuda] [http://doctorpinkerton.ifrance.com/lib/xxxx-sex/ xxxx sex] [http://tulip123456.ifrance.com/topic/canale.html canale5] [http://competitio.ifrance.com/www-donne/ www donne mature it] [http://jnk713.ifrance.com/img/styles/www-adultswim/ www adultswim] [http://competitio.ifrance.com/mature-xxx/ mature xxx] [http://tulip123456.ifrance.com/topic/ragazze-russe.html ragazze russe] [http://bakadeshi.ifrance.com/img/styles/eurosex.html eurosex] [http://mi-kkiechang.ifrance.com/nuda-gol.html nuda gol video] [http://elixirium.ifrance.com/lib/foto-nuda.html foto nuda annalisa caputo] [http://tulip123456.ifrance.com/topic/sexfilm.html sexfilm] [http://cincydj.ifrance.com/images/small/gayromeo/ gayromeo] [http://bakadeshi.ifrance.com/img/styles/sorella-racconti.html sorella racconti erotici] [http://tulip123456.ifrance.com/topic/sexy-parodius.html sexy parodius] [http://spirit-psyki.ifrance.com/lib/donne-grasse.html donne grasse nude] [http://adrienneee.ifrance.com/blog/will-you/ will you be my girl] [http://competitio.ifrance.com/helicopteros/ helicopteros] [http://doctorpinkerton.ifrance.com/lib/sesso-hot/ sesso hot] [http://mi-kkiechang.ifrance.com/nudiste.html nudiste] [http://furrysoap.ifrance.com/film-amatoriale/ film amatoriale porno] {{task}}
Compute the sum of the elements of an Array
Compute the sum of the elements of an Array


Line 11: Line 11:
$var:=0
$var:=0
For ($i;1;Size of array($list))
For ($i;1;Size of array($list))
$var:=$var $list{$i}
$var:=$var+$list{$i}
End for
End for


Line 20: Line 20:
Sum : Integer := 0;
Sum : Integer := 0;
for I in Int_Array'range loop
for I in Int_Array'range loop
Sum := Sum Int_Array(I);
Sum := Sum + Int_Array(I);
end loop;
end loop;


Line 30: Line 30:
repeat with i in array
repeat with i in array
-- very important -- list index starts at 1 not 0
-- very important -- list index starts at 1 not 0
set product to product i
set product to product + i
end repeat
end repeat


Line 42: Line 42:
50 REM Find the sum of elements in the array
50 REM Find the sum of elements in the array
60 SUM = 0
60 SUM = 0
70 FOR I = 1 TO 5: SUM = SUM ARRAY(I): NEXT I
70 FOR I = 1 TO 5: SUM = SUM + ARRAY(I): NEXT I
80 PRINT "The sum is ";SUM
80 PRINT "The sum is ";SUM


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


Line 55: Line 55:
int list[] = { 1, 2, 3 } ;
int list[] = { 1, 2, 3 } ;
int sum = 0 ;
int sum = 0 ;
for( int i = 0 ; i < 3 ; i )
for( int i = 0 ; i < 3 ; i++ )
{
{
sum = list[i];
sum += list[i];
}
}
}
}
Line 69: Line 69:
{
{
int list[] = { 1, 2, 3 } ;
int list[] = { 1, 2, 3 } ;
std::accumulate(list, list 3, 0);
std::accumulate(list, list + 3, 0);
return 0;
return 0;
}
}
Line 78: Line 78:
{
{
T accum = 0;
T accum = 0;
for (unsigned i=0; i<n; i )
for (unsigned i=0; i<n; i++)
accum = array[i];
accum += array[i];
return accum;
return accum;
}
}
Line 103: Line 103:
int arg_length = arg.Length;
int arg_length = arg.Length;


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




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


==[[Clean]]==
==[[Clean]]==
Line 128: Line 128:


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


==[[Delphi]]==
==[[Delphi]]==
Line 146: Line 146:


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


==[[Erlang]]==
==[[Erlang]]==
Line 168: Line 168:
0;
0;
sum_rec([Head|Tail]) ->
sum_rec([Head|Tail]) ->
Head sum_rec(Tail).
Head + sum_rec(Tail).


% tail-recursive definition:
% tail-recursive definition:
Line 176: Line 176:
Acc;
Acc;
sum_tail([Head|Tail], Acc) ->
sum_tail([Head|Tail], Acc) ->
sum_tail(Tail, Head Acc).
sum_tail(Tail, Head + Acc).


==[[Forth]]==
==[[Forth]]==
Line 183: Line 183:
: sum ( addr cnt -- n )
: sum ( addr cnt -- n )
0 -rot
0 -rot
cells bounds do i @ cell loop ;
cells bounds do i @ + cell +loop ;




Line 193: Line 193:
dim sum as integer = 0
dim sum as integer = 0
for index as integer = lbound(array) to ubound(array)
for index as integer = lbound(array) to ubound(array)
sum = array(index)
sum += array(index)
next
next


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


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


==[[JavaScript]]==
==[[JavaScript]]==
Line 222: Line 222:
var sum = 0;
var sum = 0;
for(var i in array)
for(var i in array)
sum = array[i];
sum += array[i];


==[[Perl]]==
==[[Perl]]==
Line 230: Line 230:
my $var;
my $var;
my @list = (1, 2, 3);
my @list = (1, 2, 3);
$var = $_ for (@list);
$var += $_ for (@list);


Alternate
Alternate
Line 245: Line 245:
my $acc = 0;
my $acc = 0;
my @list = qw(1 2 3)
my @list = qw(1 2 3)
map { $acc = $_ } @list
map { $acc += $_ } @list


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


Line 266: Line 266:


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


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


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


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


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


==[[Seed7]]==
==[[Seed7]]==
Line 307: Line 307:
begin
begin
for value range valueArray do
for value range valueArray do
sum := value;
sum +:= value;
end for;
end for;
end func;
end func;
Line 319: Line 319:


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


==[[Tcl]]==
==[[Tcl]]==
Line 326: Line 326:
Assuming the values are in a list named <tt>listname</tt>:
Assuming the values are in a list named <tt>listname</tt>:


set result [expr [join $listname ]]
set result [expr [join $listname +]]


==[[Toka]]==
==[[Toka]]==
Line 332: Line 332:


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


==[[UNIX Shell]]==
==[[UNIX Shell]]==
Line 344: Line 344:
list="1 2 3"
list="1 2 3"
for n in $list
for n in $list
do sum="$(($sum $n))"
do sum="$(($sum + $n))"
done
done
echo $sum
echo $sum
Line 352: Line 352:
sum=0
sum=0
for n
for n
do sum="$(($sum $n))"
do sum="$(($sum + $n))"
done
done
echo $sum
echo $sum
Line 360: Line 360:
sum=0
sum=0
while read n
while read n
do sum="$(($sum $n))"
do sum="$(($sum + $n))"
done
done
echo $sum
echo $sum
Line 371: Line 371:
SUM=0;
SUM=0;
for i in $LIST; do
for i in $LIST; do
SUM=$[$SUM $i];
SUM=$[$SUM + $i];
done;
done;
echo $SUM
echo $SUM

Revision as of 19:24, 26 August 2007

Task
Sum of Array
You are encouraged to solve this task according to the task description, using any language you may know.

Compute the sum of the elements of an Array

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

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

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

 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++

Compiler: 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#

 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

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

ColdFusion

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

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

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

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

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


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

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

IDL

 result = total(array)

Java

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

JavaScript

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

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

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

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

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

Interpeter: Python 2.5

 total = sum([1, 2, 3, 4, 5, 6, 7, 8, 9])

Ruby

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

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

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

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

Tcl

Assuming the values are in a list named listname:

 set result [expr [join $listname +]]

Toka

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

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