Find Anagram Mappings
Given two lists Aand B, and B is an anagram of A. B is an anagram of A means B is made by randomizing the order of the elements in A.
We want to find an index mapping P, from A to B. A mapping P[i] = j means the ith element in A appears in B at index j.
These lists A and B may contain duplicates. If there are multiple answers, output any of them.
For example, given A = [12, 28, 46, 32, 50] B = [50, 12, 32, 46, 28] We should return [1, 4, 3, 2, 0] as P = 1 because the 0th element of A appears at B, and P = 4 because the 1st element of A appears at B, and so on.
- A, B have equal lengths in range [1, 100].
- A[i], B[i] are integers in range [0, 10^5].
Credits To: leetcode.com
Leave me comments, if you have better ways to solve.
#!/usr/bin/env python ## Blog link: https://code.dennyzhang.com/find-anagram-mappings ## Basic Ideas: ## Complexity: Time O(n*n), Space O(1) ## Assumption: whether I can change B? class Solution(object): def anagramMappings(self, A, B): """ :type A: List[int] :type B: List[int] :rtype: List[int] """ length = len(A) selected_list =  * length result =  for item in A: # print("item: %d" % (item)) for i in xrange(length): if item == B[i]: result.append(i) B[i] = None break return result # s = Solution() # print s.anagramMappings([21,5,74,5,74,21], [21,5,74,74,5,21])