From 0817d0b190ef9d26e91353daf06f63e13de4d313 Mon Sep 17 00:00:00 2001 From: WHAHA-HA Date: Sat, 4 Jul 2020 09:23:16 +0530 Subject: [PATCH] Uploaded prob 231 --- Problems/231.txt | 13 +++++++++ Solutions/231.py | 69 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 82 insertions(+) create mode 100644 Problems/231.txt create mode 100644 Solutions/231.py diff --git a/Problems/231.txt b/Problems/231.txt new file mode 100644 index 0000000..8f721d0 --- /dev/null +++ b/Problems/231.txt @@ -0,0 +1,13 @@ +PROBLEM 231: + +Given a string with repeated characters, rearrange the string so that no two adjacent characters are the same. +If this is not possible, return None. + + +EXAMPLE: + +Input = "aaabbc" +Output = "ababac" + +Input = "aaab" +Output = None \ No newline at end of file diff --git a/Solutions/231.py b/Solutions/231.py new file mode 100644 index 0000000..8599b4f --- /dev/null +++ b/Solutions/231.py @@ -0,0 +1,69 @@ +''' +Problem: + +Given a string with repeated characters, rearrange the string so that no two adjacent characters are the same. +If this is not possible, return None. + +Example: + +Input = "aaabbc" +Output = "ababac" + +Input = "aaab" +Output = None +''' + +def get_unique_adjacent(string): + length = len(string) + freq = {} + + if (length == 0): return string + + # getting the character frequency + for i in range(length): + if (string[i] in freq): freq[string[i]] += 1 + else: freq[string[i]] = 1 + + sorted_freq = sorted(freq.items(), key=lambda x: x[1], reverse=True) + queue = list(sorted_freq) + + # checking if a desired string can be formed + if (length % 2 == 0): + if (sorted_freq[0][1] > length // 2): return None + else: + if (sorted_freq[0][1] > (length // 2) + 1): return None + + res = "" + + # creating the required string + while (queue): + if (len(queue) == 1): + if (queue[0][1] == 2): + res = queue[0][0] + res + queue[0][0] + break + elif (queue[0][1] == 1): + if (res[-1] != queue[0][0]): res += queue[0][0] + else: res = queue[0][0] + res + break + else: + return None + + res += queue[0][0] + queue[1][0] + + queue[0] = queue[0][0], queue[0][1]-1 + queue[1] = queue[1][0], queue[1][1]-1 + + if (len(queue) > 1 and queue[1][1] == 0): queue.pop(1) + if (len(queue) > 0 and queue[0][1] == 0): queue.pop(0) + + return res + + +# DRIVER CODE +print(get_unique_adjacent("aaabbc")) +print(get_unique_adjacent("aaabbcc")) +print(get_unique_adjacent("aaabbac")) + +# cannot form a word of the desired form +print(get_unique_adjacent("aaab")) +print(get_unique_adjacent("aaabbaa")) \ No newline at end of file