Sorting A Three-Valued Sequence

來源:互聯網
上載者:User

(1)開始只考慮了從第一個元素開始查詢,找到每個放置不對的元素nums[i],然後再他應該放置的位置targetP,交換這兩個位置的元素,結果沒有通過第三個測試

(2)仔細觀察了啟動並執行中間狀態,發現問題出在當出現這種情況是13222323113的時候,就是說當前最有的交換應該是一種A-B到B-A的,而我遇到的可用的第一個交換位置卻產生的是A-B到C-B的結果。

可是我還是做的是一個尋找的工作,每次尋找可交換點,浪費時間

(3)USACO的解答思路1是:首先找到配對的兩個填錯的地方(A-B和B-A),這樣可以計算出只交換一次就能更正的地方;然後其餘的都是需要1-2-3動3個位置,交換兩次,因此只要計數還沒有放對的位置數目,然後/3*2就得到需要的交換次數。

需要複製一份原來的數組,時間複雜度為O(n^2)

思路2:基本跟我的想法一致

思路3:更加靈巧,根據題目的規則來計算。計算出1、2、3分別的個數,然後計算出,在1中2的個數,3的個數,以此類推。那麼

min(2sin1, 1sin2) +min(2sin3, 3sin2) +min(3sin1, 1sin3)

+ 2 * (max(2sin1, 1sin2) - min(2sin1, 1sin2))

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.