將list集合,元素隨機打亂


 

  • for循環+隨機數 實現相同位置的元素交換
  • public <T> void shuffle(List<T> list) {
            int size = list.size();
            Random random = new Random();
    
            for(int i = 0; i < size; i++) {
    
                int randomPos = random.nextInt(size);
    
                T temp = list.get(i);
                list.set(i, list.get(randomPos));
                list.set(randomPos, temp);
            }
        }
  • Collections.swap實現
  • public <T> void shuffle(List<T> list) {
            int size = list.size();
            Random random = new Random();
    
            for(int i = 0; i < size; i++) {
    
                int randomPos = random.nextInt(size);
    
                Collections.swap(list, i, randomPos);
            }
        }

    Collections.shuffle實現

  • public <T> void shuffle(List<T> list)
     { 
    Collections.shuffle(list); 
    }

     


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM