恐怕我对集合和数据结构的了解不足以处理涉及哈希集的类似问题。我目前有一个循环,它在一个随机化数组中的索引的程序中。传入该方法的原始数组由所有小于 1,000 的素数组成。不包括完整的课程,因为它是更大的家庭作业的一部分。我的问题是我创建的 if 语句重复打印出数字,即使我认为我将它编码为仅在数字已经不在数组中时才打印出数字。有人可以指出我的逻辑错误吗?public static void shuffle(int[] intArray, String name){ assert intArray != null : "null!"; long seed = name.hashCode(); Random random = new Random(seed); for(int i = 0; i < 1000; i++) { int random_m = random.nextInt(intArray.length); int random_n = random.nextInt(intArray.length); int temp = intArray[random_m]; intArray[random_m] = intArray[random_n]; intArray[random_n] = temp; int zeroIndex = intArray[0]; List<Integer> myList = new ArrayList<Integer>(); if(!myList.contains(zeroIndex)) { System.out.println(zeroIndex); } myList.add(zeroIndex); }}输出的部分示例:5821 5821 5821 5821 5821 5821 5821 5821 5821 5821 5821 5821
添加回答
举报
0/150
提交
取消