java


Could anyone explain how its work? [duplicate]


I'm trying to understand the following Java exercise. Even running the debugger I don't understand the details of the second and third printout:
1, 2, 3, 4
1, 2, 4, 4
1, 2, 4, 8
I understand that the first print is the array as it is, second line prints [2] element of the array and third line [3] element. Here is the code:
public class TR1
{
public static void main(String[] args)
{
int[] v = {1, 2, 3, 4 };
print(v);
x(v, v[2] - 1);
print(v);
x(v, v[3] - 1);
print(v);
}
public static void x(int array[], int y)
{
array[y] = array[y - 1] * 2;
}
public static void print(int array[])
{
System.out.print(array[0]);
for (int i = 1; i < array.length; i++)
System.out.print(", " + array[i]);
System.out.println();
}
}
Let's see what this method does :
public static void x(int array[], int y)
{
array[y] = array[y - 1] * 2;
}
It takes the value at index y-1, multiplies it by 2, then assigns this result to the index y .
Starting array : {1,2,3,4}
The call with v[2] - 1 takes the value at index 2 (which is 3), and substracts 1, so we have y = 2.
From what we said before, the method takes the value at index 1 (y-1) which is 2, multiplies it by 2 so we get 4, and assigns that to the index 2 (y) .
Current array : {1,2,4,4}
The call with v[3] - 1 takes the value at index 3 (which is 4), and substracts 1, so we have y = 3.
From what we said before, the method takes the value at index 2 (y-1) which is 4, multiplies it by 2 so we get 8, and assigns that to the index 3 (y) .
Current array : {1,2,4,8}
Lets briefly walk you through the first things that happen. You start with this array:
1 2 3 4
No surprise when printing that.
Then you run:
x(v, v[2] -1 ) ... evaluates to
x(v, 3 - 1) ... evaluates to
x(v, 2)
Which changes the array based on:
array[y] = array[y - 1] * 2;
Lets insert y as 2 (see above):
array[2] = array[1] * 2;
array[2] = 2 * 2;
leading to:
1, 2, 4, 4
So, the real answer is: you don't even need a debugger. A piece of paper, a pen and a bit of thinking is even more efficient to uncover the "secrets" here.
print always prints the entire array. x and y are making changes to the array in between.
Keep in mind that v[x] is just an integer. For example, v[2] is initialy just 3, so v[2] - 1 = 2. Hence it modifies v[2] between the first and second call to print.

Related Links

Java EXCEPTION_ACCESS_VIOLATION (0xc0000005) while using Eclipse / IntelliJ
lineNumber: 12; columnNumber: 139; cvc-complex-type.2.4.a: Invalid content was found starting with element 'beans:bean' [closed]
Hibernate duplicates record along with null value(new row as duplicate) while saving
How to compress multiple js file and save to single file using YUI Compressor
Grails: getting old instance after persisting
How to make red-black tree generic in java
How to get use data that coming from Kafka using Spark
Best practice to pass arguments
[Suggestion]Tomcat7 automatic restart of application
How to find the missing elements in a sequence?
Why does my program keeps giving me an ArrayIndexOutOfBoundsException even tough I haven't got one
Streamig data to bigquery in google appengine - java
How to make Ebean create foreign key as “on delete no action on update no action”
JAVA matchers group [duplicate]
Cannot resolve symbol AndroidSchedulers
Java runtime exception while asking for IP address

Categories

HOME
java
gitlab
smarty
plot
sd-card
youtube-dl
google-docs
react-redux
frameworks
pivotal-cloud-foundry
pheatmap
awesome-wm
wheelnav.js
task
visual-studio-2005
vaadin7
libtiff
seaborn
fatal-error
footer
text-rendering
google-cloud-speech
chromium-embedded
sqlcipher
django-storage
uninstall
subdomains
librato
microsoft-chart-controls
javascriptcore
key-value-observing
fog
kendo-ui-grid
form-data
sequential
bitbucket-pipelines
c11
splice
galen
gzipstream
janrain
nand2tetris
scorm
qwt
powercli
lowpass-filter
setter
flow-control
hittest
dwscript
webdriverjs
sonarlint-vs
blacklist
specrun
parallel-data-warehouse
httplistener
radtreelist
url-masking
clang-static-analyzer
persist
ubuntu-10.04
yaws
freelancer.com-api
tmuxinator
sailfish-os
census
ng-animate
pyhdf
mysqltuner
odata4j
gwt-rpc
referrer
mhtml
chuck
bitsharp
dice
hosts-file
online-compilation
ohm
krl
substrings
zend-tool
exchange-server-2003
uiq3

Resources

Encrypt Message



code
soft
python
ios
c
html
jquery
cloud
mobile