HR_Minimum Swaps 2

源代码超时 看了评论区改用了字典序列。

 

#!/bin/python3

import math
import os
import random
import re
import sys

# Complete the minimumSwaps function below.
def minimumSwaps(arr):
    # n = len(arr)
    # count = 0
    # for i in range(n):
    #     if i > 0:
    #         if i == arr[i-1]:
    #             continue
    #         else:
    #             index = arr.index(i)
    #             temp = arr[i-1]
    #             arr[i-1] = arr[index]
    #             arr [index] = temp
    #             count += 1
    # return count
    ref_arr = sorted(arr)
    index_dict = {v: i for i,v in enumerate(arr)}
    swaps = 0
    
    for i,v in enumerate(arr):
        correct_value = ref_arr[i]
        if v != correct_value:
            to_swap_ix = index_dict[correct_value]
            arr[to_swap_ix],arr[i] = arr[i], arr[to_swap_ix]
            index_dict[v] = to_swap_ix
            index_dict[correct_value] = i
            swaps += 1
            
    return swaps       

if __name__ == '__main__':
    fptr = open(os.environ['OUTPUT_PATH'], 'w')

    n = int(input())

    arr = list(map(int, input().rstrip().split()))

    res = minimumSwaps(arr)

    fptr.write(str(res) + '\n')

    fptr.close()

 

posted @ 2018-10-09 11:05  夜歌乘年少  阅读(318)  评论(0编辑  收藏  举报