如何将两个 int 数组混合成唯一的 xy 坐标映射



考虑一下:

public Map<Integer, Point> setXY(int[] x, int[] y) {
     Point point;
     Map<Integer, Point> xy = new HashMap<Integer, Point>();
     int key = 0;
     for (int i = 0; i < x.length; i++) {
          for(int j = 0; j < y.length; j++) {
               point = new Point(x[i], y[j]);
               xy.put(key, point);
               key++;
          }
     }
     return xy;
}

有两个不同长度的 int 数组,我尝试为"n"点对象创建唯一的坐标。"n"表示"x.length + y.length"的值(例如n = x[3] + y[5])。然后我将这些对象添加到我的哈希图中。问题是,这个嵌套的"for"指令为"i = 2"创建,例如五个带有坐标的点:(2,1),(2,2),(2,3),(2,4)和(2,5)。我想要实现的是使用这两个给定的"x"和"y"数组完全随机化点创建。你有什么想法吗?

编辑

我现在正在考虑仅对 Map 键值进行随机化的可能性。 例如。我在地图中有 400 个对象,所以如果我知道如何从 0-400 范围内获取随机唯一(!) 值就足够了。当然,价值观不能重复。这是整个事情的关键。

在集合中有一个随机方法,您可以使用它来获取数组的随机顺序但唯一的元素。

Collections.shuffle(Arrays.asList(y));

这将打乱数组 y 中元素的顺序。然后使用 for 循环进行迭代。

最新更新