我很难为改组算法使用伪代码并将其转换为有效的 Java 代码。我正在尝试对链表进行洗牌。总的来说,该方法获取链表头的指针,并随机返回指向同一个链表头的指针。我想使用我创建的 getLength 和 getItem 方法。
public static ListElement shuffle(ListElement head){
head = head.getLength();
ListElement head2= null;
while( head == null) {
int random = (int) Math.random() * n;
for(int i=0;i<random;i++){
head= head.getNext();
}
}
return head;
}
伪代码:
A list L of length n
A new list R, empty
while L is not empty
pick a random k
such that 0<=k<= (length L)
remove the kth element of L
call it e
prepend e to R