n | from collections import Counter | n | from collections import Counter as c |
| | | |
| | | |
| class Spiral: | | class Spiral: |
n | | n | |
| def __init__(self, string=""): | | def __init__(self, s=''): |
| self.cells = Counter(string) | | self.cells = c(s) |
| | | |
| def __iter__(self): | | def __iter__(self): |
| return self.cells.elements() | | return self.cells.elements() |
| | | |
| def __add__(self, other): | | def __add__(self, other): |
| return type(self)(self.cells + other.cells) | | return type(self)(self.cells + other.cells) |
| | | |
| def __sub__(self, other): | | def __sub__(self, other): |
| return type(self)(self.cells - other.cells) | | return type(self)(self.cells - other.cells) |
| | | |
| def __mul__(self, num): | | def __mul__(self, num): |
| return type(self)(list(self)*num) | | return type(self)(list(self)*num) |
| | | |
| __rmul__ = __mul__ | | __rmul__ = __mul__ |
| | | |
| def __len__(self): | | def __len__(self): |
| return sum(self.cells.values()) | | return sum(self.cells.values()) |
| | | |
| def _square(self): | | def _square(self): |
| dx, dy = (0, 1, 0, -1), (1, 0, -1, 0) | | dx, dy = (0, 1, 0, -1), (1, 0, -1, 0) |
| F = {} | | F = {} |
| x = y = n = k = j = mx = Mx = my = My = 0 | | x = y = n = k = j = mx = Mx = my = My = 0 |
| for i, c in enumerate(self): | | for i, c in enumerate(self): |
| F[x, y] = c | | F[x, y] = c |
| mx, my, Mx, My = min(mx, x), min(my, y), max(Mx, x), max(My, y) | | mx, my, Mx, My = min(mx, x), min(my, y), max(Mx, x), max(My, y) |
| if i >= n: | | if i >= n: |
| k += 1 | | k += 1 |
| n += k | | n += k |
| j = (j+1) % 4 | | j = (j+1) % 4 |
| x, y = x+dx[j], y+dy[j] | | x, y = x+dx[j], y+dy[j] |
| return F, (mx, Mx), (my, My) | | return F, (mx, Mx), (my, My) |
| | | |
| def __str__(self): | | def __str__(self): |
| F, (mx, Mx), (my, My) = self._square() | | F, (mx, Mx), (my, My) = self._square() |
n | return "\n".join( | n | return '\n'.join( |
| "".join( | | ''.join( |
| F.get( | | F.get( |
| (x, | | (x, |
| y), | | y), |
t | " ") for x in range( | t | ' ') for x in range( |
| mx, | | mx, |
| Mx + | | Mx + |
| 1)) for y in range( | | 1)) for y in range( |
| my, | | my, |
| My + | | My + |
| 1)) | | 1)) |
| | | |