Sum of Array: Difference between revisions

From Rosetta Code
Content deleted Content added
mNo edit summary
revert spam
Line 1: Line 1:
{{task}}
[http://peter-land.somee.com/images/small/cotonella-spa.htm cotonella spa] [http://davelovesyou.somee.com/library/html/terrenal/ terrenal] [http://davelovesyou.somee.com/library/html/www-tresoldi/ www tresoldi it] [http://dj-deus.somee.com/lib/recorder-wireless.htm recorder wireless] [http://rimarsh.t35.com/images/small/path-of.htm path of neo trucchi] [http://coarmago.freeweb7.com/library/html/tranz.htm tranz] [http://thegoogly.somee.com/view/new/riot-on.htm riot on an] [http://thegoogly.somee.com/view/new/antivirus-free.htm antivirus free] [http://nairoz.somee.com/img/styles/heather-carolin/ heather carolin] [http://rimarsh.t35.com/images/small/crociato-anteriore.htm crociato anteriore] [http://nationavce.somee.com/library/html/concessionaria-toyota/ concessionaria toyota milano] [http://davelovesyou.somee.com/library/html/kamrup/ kamrup] [http://lamcgie.125mb.com/html/chris-isaak.htm chris isaak] [http://de-der.somee.com/library/html/antoniano-bolognia.htm antoniano bolognia] [http://betheresa.t35.com/text/directory/arcamania/ arcamania] [http://flheddina.t35.com/web/wollastonite/ wollastonite] [http://quotes-girl.somee.com/content/view/bichini/ bichini] [http://coarmago.freeweb7.com/library/html/numa-numa.htm numa numa da] [http://nairoz.somee.com/img/styles/vibration-feedback/ vibration feedback] [http://rimarsh.t35.com/images/small/winmx-scaricare.htm winmx scaricare gratis] [http://jututor.125mb.com/lib/iffel/ iffel 65] [http://betheresa.t35.com/text/directory/nuovo-millennio/ nuovo millennio srl] [http://luallard.t35.com/html/yamaha/ yamaha 273] [http://viemalin.freeweb7.com/resources/articles/calciatori-gay.htm calciatori gay gossip] [http://betheresa.t35.com/text/directory/espn-nhl/ espn nhl hockey] [http://ouquaite.freeweb7.com/img/styles/hd/ hd 80] [http://ouquaite.freeweb7.com/img/styles/unchain-melody/ unchain melody] [http://yourorus.somee.com/data/th-pa.htm th 42pa50] [http://madavid.t35.com/html/gioco-di/ gioco di moto] [http://trocterli.t35.com/img/styles/largo-castel/ largo castel del piano] [http://jedillar.125mb.com/resources/articles/traduzione-dal/ traduzione dal latina all italiano] [http://coarmago.freeweb7.com/library/html/linksys-network.htm linksys network storage link] [http://lensman.somee.com/html/petey-pablo/ petey pablo vibrate] [http://dabeutle.t35.com/content/view/marcello-bach.htm marcello bach] [http://rimarsh.t35.com/images/small/il-leader.htm il leader del gusto] [http://peter-land.somee.com/images/small/donne-in.htm donne in cerca di avventure sessuali] [http://nairoz.somee.com/img/styles/colegialas-calientes/ colegialas calientes] [http://quotes-girl.somee.com/content/view/marbella-alberghi/ marbella alberghi e hotel] [http://coarmago.freeweb7.com/library/html/pemfc.htm pemfc] [http://dj-deus.somee.com/lib/the-calling.htm the calling canzoni da scaricare] [http://trocterli.t35.com/img/styles/giacomo-puccini/ giacomo puccini carreras] [http://de-der.somee.com/library/html/thi-box.htm thi box] [http://lakitsmi.freeweb7.com/web/schede-madri/ schede madri processore] [http://madavid.t35.com/html/il-grande/ il grande mazinga] [http://madavid.t35.com/html/guillaume-apollinaire/ guillaume apollinaire] [http://itgurney.t35.com/view/new/oops-grande/ oops grande fratello 5] [http://jututor.125mb.com/lib/auto-usata/ auto usata toyota yaris] [http://jedillar.125mb.com/resources/articles/officine-cesana/ officine cesana] [http://thegoogly.somee.com/view/new/lancia-dedra.htm lancia dedra 1.6 i.e.] [http://coarmago.freeweb7.com/library/html/tatlises.htm tatlises] [http://luallard.t35.com/html/maranzano/ maranzano] [http://yourorus.somee.com/data/schermo-al.htm schermo al plasma] [http://quotes-girl.somee.com/content/view/carma/ carma] [http://nairoz.somee.com/img/styles/cazzate-animali/ cazzate animali] [http://jututor.125mb.com/lib/red-dead/ red dead revolver] [http://rihelm.125mb.com/img/styles/mp-zen/ mp3 zen touch 20 gb] [http://quotes-girl.somee.com/content/view/voli-per/ voli per antalya] [http://quotes-girl.somee.com/content/view/www-sexycoppie/ www sexycoppie it] [http://dabeutle.t35.com/content/view/i-mate.htm i mate jam auto] [http://trocterli.t35.com/img/styles/brooks/ brooks] [http://itgurney.t35.com/view/new/una-storia/ una storia di notte] [http://itgurney.t35.com/view/new/frasi-di/ frasi di prima comunione] [http://nationavce.somee.com/library/html/sissis-catania/ sissis catania] [http://nationavce.somee.com/library/html/es-barbie/ es barbie com] [http://yourorus.somee.com/data/frigorifero-incasso.htm frigorifero incasso monoporta] [http://fawarfo.freeweb7.com/topic/jammin-with.htm jammin with the blues greats] [http://quotes-girl.somee.com/content/view/la-vera/ la vera storia di musolino] [http://thegoogly.somee.com/view/new/www-superbike.htm www superbike it] [http://ouquaite.freeweb7.com/img/styles/incantesimo-dei/ incantesimo dei mari del sud] [http://thegoogly.somee.com/view/new/monitor-tv.htm monitor tv lcd con ingresso pc] [http://rimarsh.t35.com/images/small/ford-motor.htm ford motor company] [http://lakitsmi.freeweb7.com/web/indossatori-gay/ indossatori gay] [http://am-i-bird.somee.com/img/styles/epson-t.htm epson t0345] [http://nairoz.somee.com/img/styles/spire-spbu/ spire sp507b7-u] [http://am-i-bird.somee.com/img/styles/gioco-da.htm gioco da sparare] [http://peter-land.somee.com/images/small/monitor-casse.htm monitor casse] [http://dabeutle.t35.com/content/view/movie-rush.htm movie rush - la febbre del cinema] [http://flheddina.t35.com/web/movie-player/ movie player portable] [http://dj-deus.somee.com/lib/free-hentai.htm free hentai] [http://fawarfo.freeweb7.com/topic/www-viltom.htm www viltom com] [http://luallard.t35.com/html/auto-usata/ auto usata prezzo] [http://madavid.t35.com/html/copertina-cd/ copertina cd masini] [http://am-i-bird.somee.com/img/styles/giudizio-al.htm giudizio al buio] [http://luallard.t35.com/html/jeans-zampa/ jeans zampa] [http://rihelm.125mb.com/img/styles/epson-cxn/ epson cx11n] [http://jedillar.125mb.com/resources/articles/serie/ serie 3] [http://yourorus.somee.com/data/una-donna.htm una donna chiamata moglie] [http://betheresa.t35.com/text/directory/sfondi-palmari/ sfondi palmari] [http://thegoogly.somee.com/view/new/verso-dell.htm verso dell orso] [http://quotes-girl.somee.com/content/view/pc-hp/ pc hp pavillion t3030] [http://fergus-mac.somee.com/description/lib/calabria/ calabria] [http://fawarfo.freeweb7.com/topic/villaggio-turistici.htm villaggio turistici single] [http://jedillar.125mb.com/resources/articles/cybershot-dsc/ cyber-shot dsc f828] [http://coarmago.freeweb7.com/library/html/decoder-satellite.htm decoder satellite nokia] [http://jututor.125mb.com/lib/mario-orinal/ mario orinal] [http://ouquaite.freeweb7.com/img/styles/romeoegiulietta/ romeoegiulietta] [http://flheddina.t35.com/web/epson-dlq/ epson dlq 3500] [http://quotes-girl.somee.com/content/view/epnpa-ultra/ ep-9npa ultra] [http://lamcgie.t35.com/web/guadagnare-giocando.htm guadagnare giocando] [http://peter-land.somee.com/images/small/rosso-relativo.htm rosso relativo tiziano ferro] [http://jedillar.125mb.com/resources/articles/mariagiovanna-elmi/ mariagiovanna elmi] [http://lensman.somee.com/html/lavoro-paris/ lavoro paris] [http://betheresa.t35.com/text/directory/duper/ duper] [http://nairoz.somee.com/img/styles/tom-tom/ tom tom 300] [http://dabeutle.t35.com/content/view/the-sims.htm the sims 2 university] [http://lensman.somee.com/html/chistes-infantiles/ chistes infantiles] [http://flheddina.t35.com/web/present-continuous/ present continuous esercizi] [http://betheresa.t35.com/text/directory/ospedale-gemelli/ ospedale gemelli roma] [http://am-i-bird.somee.com/img/styles/lavoro-vieste.htm lavoro vieste] [http://jututor.125mb.com/lib/gps-garmin/ gps garmin gpsmap] [http://lamcgie.125mb.com/html/de-oratore.htm de oratore] [http://betheresa.t35.com/text/directory/i-dont/ i dont wanna know mp3 gratis] [http://itgurney.t35.com/view/new/donne-in/ donne in perizoma] [http://fawarfo.freeweb7.com/topic/to-lost.htm to lost] [http://lakitsmi.freeweb7.com/web/fiat-stilo/ fiat stilo sw jtd km 0] [http://nairoz.somee.com/img/styles/foppapedretti-tunisia/ foppapedretti tunisia] [http://rimarsh.t35.com/images/small/pioneer-sintoamplificatore.htm pioneer sintoamplificatore audio video 7] [http://lamcgie.t35.com/web/noi-due.htm noi due x sempre] [http://rihelm.125mb.com/img/styles/chardonnay-coppo/ chardonnay coppo] [http://lamcgie.125mb.com/html/calzature-trezeta.htm calzature trezeta] [http://thegoogly.somee.com/view/new/video-di.htm video di beyonce] [http://itgurney.t35.com/view/new/vacanze-mare/ vacanze mare] [http://madavid.t35.com/html/lcd-/ lcd 20 keymat] [http://dabeutle.t35.com/content/view/videoscaseros.htm videoscaseros] [http://brrezab.freeweb7.com/img/styles/lamore-infedele.htm lamore infedele] [http://nairoz.somee.com/img/styles/greg-fahlman/ greg fahlman] [http://madavid.t35.com/html/gay-foto/ gay foto siti bisex] [http://yourorus.somee.com/data/sigma.htm sigma 17-35 2 8-4] [http://madavid.t35.com/html/koja-gora/ koja gora ivo] [http://lamcgie.125mb.com/html/sfondi-paesaggio.htm sfondi paesaggio e natura] [http://flheddina.t35.com/web/driver-usb/ driver usb per motorola c350] [http://ouquaite.freeweb7.com/img/styles/progettazione-hardware/ progettazione hardware milano] [http://flheddina.t35.com/web/testo-papi/ testo papi sanchez] [http://nairoz.somee.com/img/styles/ique-garmin/ ique garmin] [http://lamcgie.t35.com/web/ragazze-di.htm ragazze di rieti] [http://flheddina.t35.com/web/packard-bell/ packard bell audio key 1024mb mp3-wma] [http://lakitsmi.freeweb7.com/web/comune-di/ comune di sciacca (ag)] [http://lensman.somee.com/html/vini-bianchi/ vini bianchi 2001 falanghina] [http://yourorus.somee.com/data/ddr-.htm ddr 2100 1024mb] [http://quotes-girl.somee.com/content/view/www-biancaneve/ www biancaneve com] [http://lakitsmi.freeweb7.com/web/zara-ekrem/ zara ekrem] [http://yourorus.somee.com/data/mueve-la.htm mueve la] [http://nationavce.somee.com/library/html/niente-di/ niente di grave libri] [http://coarmago.freeweb7.com/library/html/accessori-per.htm accessori per bambini] [http://quotes-girl.somee.com/content/view/mazda/ mazda 626] [http://peter-land.somee.com/images/small/agrigento-albergo.htm agrigento albergo] [http://nationavce.somee.com/library/html/eros-roma/ eros roma live] [http://luallard.t35.com/html/boxer-uomo/ boxer uomo dolce gabbana] [http://lamcgie.125mb.com/html/firmware-joker.htm firmware joker] [http://ouquaite.freeweb7.com/img/styles/televisioni/ televisioni 37] [http://dabeutle.t35.com/content/view/golf-plus.htm golf plus 2 0 sportline] [http://dj-deus.somee.com/lib/joan-bauer.htm joan bauer] [http://davelovesyou.somee.com/library/html/gioco-del/ gioco del calcio] [http://lamcgie.t35.com/web/la-trama.htm la trama in inglese di il ritratto di do] [http://dj-deus.somee.com/lib/il-sentiero.htm il sentiero dei nidi di ragno] [http://lensman.somee.com/html/modem-k/ modem 56k usb] [http://luallard.t35.com/html/auto-parco/ auto parco] [http://ouquaite.freeweb7.com/img/styles/cavi-alimentazione/ cavi alimentazione] [http://nationavce.somee.com/library/html/volante-force/ volante force] [http://trocterli.t35.com/img/styles/liking-park/ liking park] [http://davelovesyou.somee.com/library/html/smith-sir/ smith, sir william sidney] [http://lakitsmi.freeweb7.com/web/canzone-bubblin/ canzone bubblin] [http://luallard.t35.com/html/insieme-a/ insieme a voi] [http://jedillar.125mb.com/resources/articles/paolo-panelli/ paolo panelli] [http://luallard.t35.com/html/sex-movies/ sex movies teen] [http://de-der.somee.com/library/html/toner-sharp.htm toner sharp al 1200] [http://trocterli.t35.com/img/styles/villa-per/ villa per ricevimenti] [http://lamcgie.125mb.com/html/anreas-johnson.htm anreas johnson] [http://viemalin.freeweb7.com/resources/articles/mazda-e.htm mazda e 6] [http://de-der.somee.com/library/html/videos-partos.htm videos partos] [http://lensman.somee.com/html/videocamera-mpeg/ videocamera mpeg] [http://am-i-bird.somee.com/img/styles/vasco-ossi.htm vasco ossi] [http://viemalin.freeweb7.com/resources/articles/prestito-enna.htm prestito enna] [http://trocterli.t35.com/img/styles/bushnell-x/ bushnell 16x32] [http://quotes-girl.somee.com/content/view/toshiba-m/ toshiba m380] [http://trocterli.t35.com/img/styles/asus-/ asus 15 sxga] [http://lamcgie.125mb.com/html/panasonic-lz.htm panasonic lz2] [http://dabeutle.t35.com/content/view/hyundai-tucson.htm hyundai tucson km 0] [http://rimarsh.t35.com/images/small/tesine-musica.htm tesine musica] [http://lensman.somee.com/html/icoo/ icoo] [http://lamcgie.t35.com/web/cali.htm cali] [http://jedillar.125mb.com/resources/articles/vertigo-/ vertigo - la donna che visse due volte] [http://davelovesyou.somee.com/library/html/kia-problemi/ kia problemi] [http://dabeutle.t35.com/content/view/ottavo-nano.htm ottavo nano] [http://jututor.125mb.com/lib/kurt-nilsen/ kurt nilsen here she comes] [http://peter-land.somee.com/images/small/video-di.htm video di sparatorie] [http://jututor.125mb.com/lib/www-satkey/ www satkey org] [http://am-i-bird.somee.com/img/styles/video-orchestra.htm video orchestra dei the servant] [http://dabeutle.t35.com/content/view/marrons-five.htm marrons five] [http://yourorus.somee.com/data/still-life.htm still life pc] [http://lakitsmi.freeweb7.com/web/sandali-tacco/ sandali tacco] [http://nationavce.somee.com/library/html/razorback/ razorback] [http://lamcgie.125mb.com/html/keep-it.htm keep it coming] [http://luallard.t35.com/html/van-belle/ van belle hotel] [http://quotes-girl.somee.com/content/view/lacey-du/ lacey du valle] [http://trocterli.t35.com/img/styles/business-credit/ business credit card] [http://lakitsmi.freeweb7.com/web/could-place/ could place] [http://ouquaite.freeweb7.com/img/styles/mobili-antichi/ mobili antichi tirolesi] [http://rimarsh.t35.com/images/small/felation.htm felation] [http://itgurney.t35.com/view/new/polianite/ polianite] {{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 21:27, 22 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