Retrieving an Element of an Array: Difference between revisions

From Rosetta Code
Content added Content deleted
mNo edit summary
Line 1: Line 1:
{{task}}
[http://squoi-oop.ifrance.com/topic/lamore-senza/ lamore senza volto] [http://trumanburb.ifrance.com/view/new/baseball-del.htm baseball del pinguino] [http://krychan.ifrance.com/content/view/taylor-donna.htm taylor donna] [http://alishca-st.ifrance.com/text/directory/boyle-kay.htm boyle, kay] [http://smegmacheez.ifrance.com/content/view/uvet-american/ uvet american express] [http://atrayah.ifrance.com/topic/strega-di.htm strega di blair] [http://flawedamythyst.ifrance.com/img/styles/george-clooney.htm george clooney collection] [http://lekusya.ifrance.com/library/html/toner-laser/ toner laser stampante] [http://atrayah.ifrance.com/topic/toshiba-media.htm toshiba media center] [http://sm4.ifrance.com/lib/ostelli-londra/ ostelli londra] [http://trumanburb.ifrance.com/view/new/mercedes-.htm mercedes 220 sw] [http://smegmacheez.ifrance.com/content/view/roberto-bignoli/ roberto bignoli] [http://cocopuff66.ifrance.com/text/directory/gigabyte-gakns/ gigabyte ga-k8ns] [http://alishca-st.ifrance.com/text/directory/trapano-a.htm trapano a percussione] [http://gabe95.ifrance.com/html/ford-mustang/ ford mustang 1973] [http://mfirishka.ifrance.com/view/new/acqua-di.htm acqua di bulgari] [http://sm4.ifrance.com/lib/samsung-flat/ samsung flat] [http://gajar.ifrance.com/html/tarabusino.htm tarabusino] [http://lightmyfire0214.ifrance.com/topic/io-caterina/ io, caterina] [http://atrayah.ifrance.com/topic/cronache-di.htm cronache di oggi] [http://krychan.ifrance.com/content/view/lovely-sara.htm lovely sara] [http://zeakk.ifrance.com/resources/articles/caporciano.htm caporciano] [http://alishca-st.ifrance.com/text/directory/testi-canzoni.htm testi canzoni maroon5] [http://smegmacheez.ifrance.com/content/view/contratto-affitto/ contratto affitto] [http://smegmacheez.ifrance.com/content/view/capitulos-sailor/ capitulos sailor moon] [http://mfirishka.ifrance.com/view/new/every-changing.htm every changing keane] [http://gajar.ifrance.com/html/rossignol-s.htm rossignol 9s oversize] [http://nokros.ifrance.com/data/isola-sant/ isola sant antioco] [http://gabe95.ifrance.com/html/ricordati-sempre/ ricordati sempre] [http://call-shotgun.ifrance.com/view/new/mision-imposible/ mision imposible] [http://lightmyfire0214.ifrance.com/topic/canzone-mia/ canzone mia] [http://horcrionebay.ifrance.com/resources/articles/ostaggi-in.htm ostaggi in russia] [http://squoi-oop.ifrance.com/topic/berlingo-usato/ berlingo usato] [http://dejablu503.ifrance.com/description/lib/airone-snc.htm airone snc] [http://alishca-st.ifrance.com/text/directory/ms-works.htm ms works] [http://gajar.ifrance.com/html/occ.htm occ] [http://squoi-oop.ifrance.com/topic/gays-fotos/ gays fotos] [http://krychan.ifrance.com/content/view/climeg.htm climeg] [http://krychan.ifrance.com/content/view/terri-clark.htm terri clark] [http://sm4.ifrance.com/lib/planet-phunk/ planet phunk] [http://atrayah.ifrance.com/topic/forno-incasso.htm forno incasso tangenziale] [http://atrayah.ifrance.com/topic/hop.htm hop] [http://sm4.ifrance.com/lib/acer-n/ acer n30 car] [http://gabe95.ifrance.com/html/zingaro-barone/ zingaro barone] [http://alishca-st.ifrance.com/text/directory/lavvocato-difensore.htm lavvocato difensore] [http://joshuaw-wise.ifrance.com/img/styles/warmia/ warmia] [http://atrayah.ifrance.com/topic/christchurch-shopping.htm christchurch shopping] [http://lightmyfire0214.ifrance.com/topic/henry-kloss/ henry kloss model two] [http://gajar.ifrance.com/html/imprese-decorazione.htm imprese decorazione] [http://squoi-oop.ifrance.com/topic/tejidos/ tejidos] [http://zeakk.ifrance.com/resources/articles/bilancia-neonato.htm bilancia neonato] [http://lekusya.ifrance.com/library/html/bagnetto-viaggio/ bagnetto viaggio] [http://squoi-oop.ifrance.com/topic/whirlpool/ whirlpool 8103] [http://joshuaw-wise.ifrance.com/img/styles/lettori-dvd/ lettori dvd vhs samsung] [http://gabe95.ifrance.com/html/aquolina-wafer/ aquolina wafer] [http://zeakk.ifrance.com/resources/articles/digiland-cupido.htm digiland cupido] [http://lekusya.ifrance.com/library/html/tasso-irs/ tasso irs 3 anni] [http://joshuaw-wise.ifrance.com/img/styles/debica-frigo/ debica frigo] [http://lightmyfire0214.ifrance.com/topic/indispensa/ indispensa] [http://alishca-st.ifrance.com/text/directory/decoder-ricevitore.htm decoder ricevitore digitale sat] [http://squoi-oop.ifrance.com/topic/print-server/ print server d-link] [http://sm4.ifrance.com/lib/car-registrations/ car registrations for sale] [http://sm4.ifrance.com/lib/mp-creative/ mp3 creative zen micro 5gb] [http://horcrionebay.ifrance.com/resources/articles/exnovo.htm exnovo] [http://zeakk.ifrance.com/resources/articles/danny-ashe.htm danny ashe] [http://sm4.ifrance.com/lib/www-jumping/ www jumping it] [http://gabe95.ifrance.com/html/l-amore/ l amore immaginato] [http://mfirishka.ifrance.com/view/new/per-non.htm per non dimenticarti] [http://dejablu503.ifrance.com/description/lib/driver-adapter.htm driver adapter cm18330] [http://nokros.ifrance.com/data/paloma-picasso/ paloma picasso - minotaure] [http://krychan.ifrance.com/content/view/televisore-plasma.htm televisore plasma 28] [http://horcrionebay.ifrance.com/resources/articles/negozi-original.htm negozi original fans] [http://flawedamythyst.ifrance.com/img/styles/fiat-abbigliamento.htm fiat abbigliamento] [http://mfirishka.ifrance.com/view/new/digimon.htm digimon 02] [http://zeakk.ifrance.com/resources/articles/cane-trasportino.htm cane trasportino per aereo] [http://lightmyfire0214.ifrance.com/topic/prince-of/ prince of persia 2] [http://alishca-st.ifrance.com/text/directory/la-danse.htm la danse de zorba] [http://dejablu503.ifrance.com/description/lib/c.htm c 460] [http://gabe95.ifrance.com/html/ragazza-singola/ ragazza singola] [http://cocopuff66.ifrance.com/text/directory/new-beetle/ new beetle cabrio] [http://cocopuff66.ifrance.com/text/directory/immagini-di/ immagini di donne bellissime nude] [http://zeakk.ifrance.com/resources/articles/contratto-di.htm contratto di soggiorno] [http://alishca-st.ifrance.com/text/directory/maschere-di.htm maschere di lusso] [http://dejablu503.ifrance.com/description/lib/religione-antica.htm religione antica grecia] [http://nokros.ifrance.com/data/lacie-d/ lacie d2 250gb] [http://squoi-oop.ifrance.com/topic/hifi-mp/ hifi mp3 dvd] [http://zeakk.ifrance.com/resources/articles/aspirapolvere-robot.htm aspirapolvere robot electrolux] [http://flawedamythyst.ifrance.com/img/styles/motore-occasioni.htm motore occasioni] [http://smegmacheez.ifrance.com/content/view/in-viaggio/ in viaggio con papa] [http://lightmyfire0214.ifrance.com/topic/black-an/ black an p] [http://atrayah.ifrance.com/topic/ati-radeon.htm ati radeon 9600 se 128mb] [http://squoi-oop.ifrance.com/topic/everhart/ everhart] [http://trumanburb.ifrance.com/view/new/netscape-com.htm netscape com] [http://krychan.ifrance.com/content/view/kwekwe.htm kwekwe] [http://lekusya.ifrance.com/library/html/athlon-socket/ athlon socket 939] [http://horcrionebay.ifrance.com/resources/articles/filmografia-di.htm filmografia di alfred hitchcock] [http://lekusya.ifrance.com/library/html/concessionario-auto/ concessionario auto milano] [http://atrayah.ifrance.com/topic/easyshare-z.htm easyshare z730] [http://atrayah.ifrance.com/topic/divisorio-per.htm divisorio per animali accessori auto] [http://sm4.ifrance.com/lib/frigoriferi-ariston/ frigoriferi ariston classe a no frost] [http://trumanburb.ifrance.com/view/new/atlante-geografico.htm atlante geografico mondadori] [http://squoi-oop.ifrance.com/topic/obsesion-karaoke/ obsesion karaoke gratis] [http://atrayah.ifrance.com/topic/hotel-ilga.htm hotel ilga] [http://trumanburb.ifrance.com/view/new/sailor-moon.htm sailor moon avi] [http://smegmacheez.ifrance.com/content/view/pizzicato/ pizzicato5] [http://alishca-st.ifrance.com/text/directory/tannini.htm tannini] [http://horcrionebay.ifrance.com/resources/articles/milano-malta.htm milano malta] [http://nokros.ifrance.com/data/la-miss/ la miss perde lo slip] [http://gajar.ifrance.com/html/castres.htm castres] [http://smegmacheez.ifrance.com/content/view/autoambulanza/ autoambulanza] [http://trumanburb.ifrance.com/view/new/volo-aereo.htm volo aereo catania santo domingo] [http://smegmacheez.ifrance.com/content/view/hosting-provider/ hosting provider] [http://gajar.ifrance.com/html/gepy.htm gepy] [http://sm4.ifrance.com/lib/sapphire-radeon/ sapphire radeon x700 256mb pci-e lite] [http://dejablu503.ifrance.com/description/lib/dvd-player.htm dvd player 8] [http://mfirishka.ifrance.com/view/new/i-giganti.htm i giganti della giungla] [http://smegmacheez.ifrance.com/content/view/mail-bomber/ mail bomber] [http://call-shotgun.ifrance.com/view/new/auto-stereo/ auto stereo] [http://flawedamythyst.ifrance.com/img/styles/computer-design.htm computer design] [http://nokros.ifrance.com/data/giochi-xxx/ giochi xxx] [http://dejablu503.ifrance.com/description/lib/www-confitarma.htm www confitarma it] [http://lightmyfire0214.ifrance.com/topic/cha-cha/ cha cha cha] [http://mfirishka.ifrance.com/view/new/forrest-harvey.htm forrest harvey] [http://lekusya.ifrance.com/library/html/revisione-cambi/ revisione cambi] [http://sm4.ifrance.com/lib/radio-pc/ radio pc] [http://nokros.ifrance.com/data/hdmi/ hdmi 26] [http://call-shotgun.ifrance.com/view/new/lettore-divx/ lettore divx con uscita usb] [http://cocopuff66.ifrance.com/text/directory/ygoogle/ ygoogle] [http://joshuaw-wise.ifrance.com/img/styles/oakley-xx/ oakley xx black] [http://sm4.ifrance.com/lib/caricatore-cd/ caricatore cd per autoradio] [http://squoi-oop.ifrance.com/topic/pourquoi-automatise/ pourquoi automatise t on] [http://lightmyfire0214.ifrance.com/topic/darklight-conflict/ darklight conflict] [http://horcrionebay.ifrance.com/resources/articles/diesel-calzature.htm diesel calzature] [http://call-shotgun.ifrance.com/view/new/sony-t/ sony t5 nera] [http://alishca-st.ifrance.com/text/directory/hamlet-zelig.htm hamlet zelig usb] [http://gajar.ifrance.com/html/volkswagen-km.htm volkswagen km o] [http://flawedamythyst.ifrance.com/img/styles/ufficio-gorizia.htm ufficio gorizia] [http://gabe95.ifrance.com/html/piazza-affari/ piazza affari] [http://gabe95.ifrance.com/html/serena-gf/ serena gf nuda] [http://gabe95.ifrance.com/html/malmesteen/ malmesteen] [http://nokros.ifrance.com/data/healing-garden/ healing garden] [http://lekusya.ifrance.com/library/html/macchina-neve/ macchina neve] [http://lekusya.ifrance.com/library/html/we-love/ we love to love] [http://trumanburb.ifrance.com/view/new/centerfold.htm centerfold] [http://squoi-oop.ifrance.com/topic/prenotazioni-albergo/ prenotazioni albergo toscana] [http://alishca-st.ifrance.com/text/directory/india-song.htm india song] [http://cocopuff66.ifrance.com/text/directory/argo/ argo 12000] [http://gabe95.ifrance.com/html/fratello-sole/ fratello sole sorella luna dolce sentire] [http://lekusya.ifrance.com/library/html/home-divx/ home divx wireless] [http://squoi-oop.ifrance.com/topic/calendario-inzaghi/ calendario inzaghi] [http://horcrionebay.ifrance.com/resources/articles/colin-farrel.htm colin farrel] [http://squoi-oop.ifrance.com/topic/telecamera-nascosta/ telecamera nascosta] [http://trumanburb.ifrance.com/view/new/tettone-enormi.htm tettone enormi] [http://alishca-st.ifrance.com/text/directory/eyes-of.htm eyes of ranger] [http://cocopuff66.ifrance.com/text/directory/passeggino-navetta/ passeggino navetta carrozzine] [http://zeakk.ifrance.com/resources/articles/mondiale-trial.htm mondiale trial 2004] [http://zeakk.ifrance.com/resources/articles/immagini-fiumicino.htm immagini fiumicino] [http://joshuaw-wise.ifrance.com/img/styles/immagination/ immagination] [http://lekusya.ifrance.com/library/html/catalogo-accesori/ catalogo accesori moto guzzi] [http://horcrionebay.ifrance.com/resources/articles/fujifilm-finepix.htm fujifilm finepix f 10] [http://call-shotgun.ifrance.com/view/new/carte-notti/ carte notti] [http://horcrionebay.ifrance.com/resources/articles/cerato-gaetano.htm cerato gaetano] [http://sm4.ifrance.com/lib/grande-e/ grande e fauto] [http://lekusya.ifrance.com/library/html/volo-hotel/ volo hotel maldive] [http://flawedamythyst.ifrance.com/img/styles/primare-a.htm primare a30 2] [http://gajar.ifrance.com/html/nx.htm nx 4090] [http://dejablu503.ifrance.com/description/lib/cuffie-digital.htm cuffie digital surround] [http://squoi-oop.ifrance.com/topic/compil/ compil] [http://smegmacheez.ifrance.com/content/view/auto-scoppio/ auto scoppio modellismo] [http://lekusya.ifrance.com/library/html/capannone-vendita/ capannone vendita] [http://dejablu503.ifrance.com/description/lib/ieee-pcmcia.htm ieee1394 pcmcia] [http://joshuaw-wise.ifrance.com/img/styles/ucds-program/ ucds program] [http://sm4.ifrance.com/lib/albergo-economici/ albergo economici barcellona] [http://horcrionebay.ifrance.com/resources/articles/donna-catania.htm donna catania] [http://lightmyfire0214.ifrance.com/topic/terranova/ terranova] [http://squoi-oop.ifrance.com/topic/real-one/ real one player] [http://dejablu503.ifrance.com/description/lib/blue-marine.htm blue marine] [http://smegmacheez.ifrance.com/content/view/concessionario-alfa/ concessionario alfa romeo 156] [http://alishca-st.ifrance.com/text/directory/los-doce.htm los doce discipulos] [http://dejablu503.ifrance.com/description/lib/www-studio.htm www studio92 com] [http://lekusya.ifrance.com/library/html/greco-tufo/ greco tufo vini e liquori] [http://cocopuff66.ifrance.com/text/directory/cucurrucu-paloma/ cucurrucu paloma] [http://gabe95.ifrance.com/html/tommaso/ tommaso] [http://joshuaw-wise.ifrance.com/img/styles/peter-macnicol/ peter macnicol] [http://atrayah.ifrance.com/topic/hbh-.htm hbh 300 sony] [http://cocopuff66.ifrance.com/text/directory/caslon-william/ caslon, william] [http://smegmacheez.ifrance.com/content/view/benq-e/ benq e300] [http://call-shotgun.ifrance.com/view/new/fiat-bravo/ fiat bravo gt jtd] [http://gajar.ifrance.com/html/range-rover.htm range rover se] [http://lekusya.ifrance.com/library/html/milly-dabbraccio/ milly dabbraccio] [http://mfirishka.ifrance.com/view/new/www-entel.htm www entel pcs cl] [http://cocopuff66.ifrance.com/text/directory/yo-tomo/ yo tomo licor yo tomo cerveza y me gusta] [http://cocopuff66.ifrance.com/text/directory/misure-di/ misure di sicurezza] [http://joshuaw-wise.ifrance.com/img/styles/mvimc-canon/ mv6imc canon] [http://horcrionebay.ifrance.com/resources/articles/hey-attack.htm hey attack] [http://gabe95.ifrance.com/html/wordsworth/ wordsworth] [http://lekusya.ifrance.com/library/html/deumidificatore-condizionatore/ deumidificatore condizionatore] [http://mfirishka.ifrance.com/view/new/tomtom-mobile.htm tomtom mobile 5 nokia 9300] [http://alishca-st.ifrance.com/text/directory/luciano-pavarotti.htm luciano pavarotti vincero] [http://smegmacheez.ifrance.com/content/view/favara/ favara] {{task}}


In this task, the goal is to retrieve an element of an [[array]].
In this task, the goal is to retrieve an element of an [[array]].
Line 15: Line 15:
mov esi, array_offset
mov esi, array_offset
mov ebx, 2
mov ebx, 2
mov eax, [esi ebx*4]
mov eax, [esi+ebx*4]


==[[ActionScript]]==
==[[ActionScript]]==
Line 54: Line 54:
}
}
==[[C plus plus|C ]]==
==[[C plus plus|C++]]==
[[Category:C plus plus|C ]]
[[Category:C plus plus|C++]]


template<typename T>
template<typename T>
Line 139: Line 139:
Forth does not have special syntax for array access. Address arithmetic is used to access contiguous memory.
Forth does not have special syntax for array access. Address arithmetic is used to access contiguous memory.
create array 1 , 2 , 3 , 4 ,
create array 1 , 2 , 3 , 4 ,
array 2 cells @ . \ 3
array 2 cells + @ . \ 3


==[[IDL]]==
==[[IDL]]==

Revision as of 21:46, 24 August 2007

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

In this task, the goal is to retrieve an element of an array.

4D

  ` first element
$elem:=$array{1}

X86 assembly

Assembler: nasm

mov esi, array_offset
mov ebx, 2
mov eax, [esi+ebx*4]

ActionScript

var arr:Array = new Array(1,2,3);
var myVar:Number = arr[1];
// the value of myVar is: 2

Ada

Array indexed by an enumerated type. Ada enumerated types are discrete non-numeric types.

type Days is (Mon, Tue, Wed, Thu, Fri, Sat, Sun);
type Daily_Counts is array(Days) of Natural;
This_week : Daily_Counts := (200, 212, 175 220, 201, 120, 0);
Monday_Sales : Natural;
Monday_Sales := This_Week(Mon); 

Monday_Sales is assigned 200

AppleScript

on getArrayValue(array, location)
    -- very important -- The list index starts at 1 not 0
    return item location in array
end getArrayValue

C

 int array_index(int array[], int index) {
   return array[index];
 }

C#

 int getArrayValue( int values[], int index ) {
   return values[index];
 }
 

C++

 template<typename T>
 T array_index(T array[], size_t index) {
   return array[index];
 }

ColdFusion

<cfset arr = ArrayNew(1)>
<cfset arr[1] = "one">
<cfset arr[2] = "2">
<cfset arr[3] = 3>
<cfset var = arr[1]>

The value of var is "one"

ColdFusion Arrays are NOT zero-based, their index begins at 1

Common Lisp

  (defun array-value (array index)
    (aref array index))

Delphi/Object Pascal/Turbo Pascal/Standard Pascal

Array's in all the flavors of pascal can be of any valid base type, or user defined type ( which are all made up of base types ) and are multi-dimensional. With Delphi dynamic arrays were defined but had been used in pascal since its inseption.

A Static array defintion:

foo : array[1..10] of integer; { The base index is ONE }

The base index can be freely chosen:

foo: array[7 .. 16] of integer; { The base index is 7 }

Indeed, the "1 .. 10" resp. "7 .. 16" are actually types: they are integer subrange types. Arrays can also be indexed by enumeration types or enumeration subrange types:

type
 rainbowcolor = (red, orange, yellow, green, blue, violet);
var
 foo: array[rainbowcolor] of integer;
 bar: array[yellow .. blue] of integer;
 i: integer
begin
 i := foo[red]; { allowed indices are red, orange, yellow, green, blue, violet }
 i := bar[green]; { allowed indices are yellow, green, blue }
end;

A Dynamic Array type in Delphi:

foo : array of integer ; // The base index is ZERO

An "old school" dynamic array in the various flavors of pascal

foo : array[0..0] of integer;  // The base index is ZERO

A dynamic array in Extended Pascal:

type
 intarray(n: integer) = array[1 .. n] of integer; { base index 1 }
var
 foo: ^intarray;
begin
 new(foo, 10); { foo now has index 1 to 10 }
 i := foo[2];
 dispose(foo); { get rid of the array }
end;

In the case of the static array, the compiler generates the code to allocate the required memory to hold 10 integers.

In the Delphi style ---dynamic--- array you must set its length:

SetLength(foo,10);  // this array will no hold 10 integers

In the "old school" style of dynamic arrays, you created a point to the zero length declaration and then allocated memory to it with GetMem

pFoo : ^Foo ;
Foo  : array[0..0] of integer ;

All arrays are accessed the same way regardless of declaration method.

i : integer ;

i := foo[n] ;

where n is the array index who's base is either 1 or 0 depending on how it was declared.

Erlang

Erlang lists are 1-based which means that the index must be within the bounds (1 .. length(List)):

Value = lists:nth(Index, List).

Forth

Forth does not have special syntax for array access. Address arithmetic is used to access contiguous memory.

create array 1 , 2 , 3 , 4 ,
array 2 cells + @ .    \ 3

IDL

 ; this is allowed:
 result = arr(5) 
 ; but this is preferred:
 result = arr[5]

The form with square brackets is preferred as it unambiguously constitutes array access, while the version with round ones can conflict with a function call if there are both a function and an array with the same name arr.

Java

public Object getArrayElem(Object[] array, int pos) {
    return array[pos];
}

JavaScript

var element = array[index];

mIRC

Interpeter: mIRC Script Editor

Library: mArray Snippet

 alias readmyarray { echo -a $array_read(MyArray, 2, 3) }

Perl

Interpreter: Perl 5.8.8

$elem = $array[0];

PHP

$array = array('php', 'has', 'arrays');
// First element 
$elem  = $array[0];

Pop11

lvars ar = {1 two 'three'};
lvars elem;
;;; Access second element and assign to variable elem
ar(2) -> elem;

This example uses the simplest possible array (a vector). Pop11 has more general arrays, but in all cases access follows the same pattern, and look the same as procedure (function) call.

Python

Interpreter: Python 2.5

The item is an element in a list at a given index

 item = aList[index]

or

To use a list like a stack be it FIFO/LIFO

 aList.pop()  # Pop last item in a list
 aList.pop(0) # Pop first item in a list

Note: When using the pop() method, the element is removed from the list.

Ruby

 ary = ['Ruby','rules','big','time']
 #the first element
 element = ary[0]
 #or
 element = ary.first
 # => element = 'Ruby'
 #the last element
 element = ary[-1]
 #or
 element = ary.last
 # => element = 'time'
 #retrieving different values at once
 elements = ary.values_at(0,2,3)
 # => elements = ['Ruby','big','time']
 #select the first element of length 3
 element = ary.find{|el|el.length==3}
 # => element = "big"

Smalltalk

  "Retrieve second element of an array"
  index := 2
  element := anArray at: index

Tcl

All arrays in Tcl are associative. If "key" is the variable that holds the key of the element to be retrieved, then

 set result $array($key)

Toka

This retrieves the value 20 from the second item in the array:

 3 cells is-array table
 ( Populate the array )
 10 0 table put-element
 20 1 table put-element 
 30 2 table put-element
 
 table 1 get-element