java - 数组洗牌(具有相同的开始值和结束值)

标签 java arrays random graph shuffle

我目前正在解决旅行推销员问题,但在生成具有相同开始值和结束值的随机路径时遇到问题

这是我当前的路径(访问城市的路径)

0 1 2 3 4 5 6 7 8 9 10 11 12 13 38 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 14 39 40 41 42 43 44 45 46 47 48 49 50 51 0

看看最后一个节点如何回到0(TSP逻辑)

现在我正在尝试随机洗牌这个数组,因为随机起点会比其他点生成更好的结果但是我知道如何使用集合来洗牌数组,但这会随机洗牌每个值

基本上,我正在尝试创建一种方法来随机打乱数组,但起始值和结束值必须相同,并且每个数字必须不同 0-51

这是我当前的代码,它基本上对数组进行洗牌并将最后一个索引设置为第一个索引

  static void shuffleArray(int[] ar)
   {
// If running on Java 6 or older, use `new Random()` on RHS here
Random rnd = new Random();
for (int i = ar.length - 1; i > 0; i--)
{
  int index = rnd.nextInt(i + 1);
  // Simple swap
  int a = ar[index];
  ar[index] = ar[i];
  ar[i] = a;
}

ar[ar.length-1]=ar[0];
 }

但是由于某种原因这给了我重复的值

最佳答案

你能不能删除开始和结束位置,打乱数组,然后再次添加开始和结束位置?

关于java - 数组洗牌(具有相同的开始值和结束值),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49217073/

相关文章:

C 模运算符在我的代码中对随机生成的整数表现异常

python - 无法在 Python 中生成不同的随机数

c++ - 当我的代码在函数范围之外时,为什么会出现编译器错误 "does not name a type"?

java - 如何将 hexString 转换为 SWT Color?

java - 无法将 Statement 声明为实例变量

javascript - 循环遍历两个对象数组以将匹配值推送到新数组在 React 中不起作用,但在 JS Fiddle 中起作用

arrays - 旋转 kotlin 数组

java - 让 Sprite 像时钟指针一样旋转?

java - List<Integer> 递归求和

我可以将二维数组的单行或单列用作 C 中的单维数组吗?