I have an array in the form of 'int[][]
' that represents the co-ordinates of a small grid. Each co-ordinate has been assigned its own value. eg array[0][4] = 28
......
I have two questions. Firstly, how do I iterate through all the stored values. Secondly, I want to be able to input a value and have its specific co-ordinates in the grid returned. What would be the best way to approach this?
Thank you for any help!
You'll be happiest if you block all these collections inside a single class and don't expose them in any way.
This means moving your search and lookup routines into this class as well.
For storage, everybody's covered iterating, add a hashtable and a lookup. I put this comment on nickolai's post:
Store new Integer(ix + iy * 1000) as the value in your hash table. If your y index can go over 1000 use a bigger number--ints are really big. To get it back use ix=val%1000, iy=val/1000.
If your array and hashtable are encapsulated in the same class, the rest of your code will be pretty easy to write and a lot cleaner.
to iterate over the values use loops:
to access the coordinates based on the value you would need some sort of double hashmap (look a at java.util.HashMap) but i am aware of nothing that does so directly
There's generally no way to find the specific coordinates of a particular value except by going through the array and searching for it. However, if the values in the array are guaranteed to be unique (i.e. each value only occurs in one cell), you could maintain a separate array as an index, which stores the coordinates of each value indexed by the value.
To iterate over all the elements in the grid try this:
Use nested for loops to iterate over the x and y dimensions, which lets you go over each value, one at a time.
For inputting a value, just do the same as above, but look for a match to your requested value.
You can iterate with either for loops or enhanced for loops:
or
The first version would be the easiest solution to the "find the co-ordinates" question - just check whether the value in the inner loop is correct.