荷蘭國旗問題(鍊錶)

2021-09-12 23:37:24 字數 831 閱讀 2909

用三個桶,每個桶包括(鍊錶的頭和鍊錶的尾),三個桶分別是less, equal, more.遍歷一次鍊錶把數值放入相應的桶。

public

class

test_demo

}public

static node lessequalmore

(node head,

int num)

else

if(head.value==num)

else

if(head.value>num)

head=next;}if

(lessend!=null)

//拼接三個桶

else

if(morestart!=null)

lessend.next=morestart;

}else

if(equalend!=null)

return lessstart=lessstart==null?

(equalstart==null?morestart:equalstart)

:lessstart;

//返回頭結點

}public

static

void

printlinkedlist

(node head)

system.out.

println()

;}public

static

void

main

(string[

] args)

}

另一種方法就是把節點存入陣列中,再根據陣列的荷蘭國旗問題求解。

荷蘭國旗問題

上方的便是乙個荷蘭國旗,從圖中我們可以很清楚的看出它的特點,它有三個區域組成,即紅,白,藍。好,現在我們的問題出來了。現在我們面前有一張桌子,桌子上整齊的擺放著紅色,白色,藍色三種線條,但他們的順序是凌亂的。我們的要求是 用乙個演算法把這些線條挑出來重新擺放順序,最後的結果就像上圖的荷蘭國旗,紅色在...

荷蘭國旗問題

問題 荷蘭國旗是由紅白藍三種顏色組成,現假設很多這三種顏色的線被打亂放置,要求從頭掃瞄一遍,3種顏色自然分開,顏色順序是紅,白,藍。問題分析 1 編碼 題目中有三種顏色,可以用0 紅,1 白,2 藍進行編碼。3 演算法 a 把n個0,1,2三種元素隨機放入陣列模擬很多這三種顏色的線被打亂放置的場景 ...

荷蘭國旗問題

荷蘭的國旗由紅色 白色和藍色3種顏色組成。現在假設有很多這3種顏色的線被存放在乙個陣列裡,要求每次操作僅能進行一次交換,在原陣列的基礎上操作。待對陣列進行一遍掃瞄後,3種顏色自然分開,顏色順序為紅 白 藍。另外,要求在o n 的複雜度下,是移動次數最少。荷蘭國旗問題 include include ...