题目思路:这道题目跟没有重复项数字的所有排列 的做法其实是类似的,只不过区别在于有了重复的数字,如果不加以处理,还是按照原来的方法去做的话,那么就可能会出现重复的结果。 例如:[1,1,2]要是利用原先的做***算出两个[1,1,2],虽然是第一个1和第二个1,但是结果都是112。 所以要避免上面出现的结果,解决这道题目,我们可以利用一个mark数组在标记当前元素是否已经被选择过了,从而避免得到重复的排列。 回溯 import java.util.*; public class Solution { //用于标记是否访问过 boolean []mark; public ArrayList&...