#include <float.h>
#include <inttypes.h>
#include <limits.h>
#include <math.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <unistd.h>
#ifdef __cplusplus
#include <bits/stdc++.h>
#endif
void rsortr_u32(void *base, const int count) {
  uint32_t *a = base;
  uint32_t *b = malloc(count * sizeof(uint32_t));
  int c[0x100];
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (0 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (0 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (1 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (1 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (2 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (2 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (3 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (3 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  free(b);
}
int32_t nextint(void) {
  char c = getchar_unlocked();
  while (c != '-' && (c < '0' || '9' < c))
    c = getchar_unlocked();
  int s = 0;
  if (c == '-') {
    s = 1;
    c = getchar_unlocked();
  }
  uint32_t x = 0;
  while ('0' <= c && c <= '9') {
    x = x * 10 + c - '0';
    c = getchar_unlocked();
  }
  return s ? -x : x;
}
char a[100000];
char b[100000];
int main(void) {
  int n = nextint();
  for (int i = 0; i < n; i++) {
    a[i] = getchar_unlocked() & 1 ^ 1;
  }
  for (int k = 0; k < 4; k++) {
    b[0] = k & 1;
    b[1] = k >> 1;
    for (int i = 2; i < n; i++) {
      b[i] = b[i - 2] ^ b[i - 1] ^ a[i - 1];
    }
    if ((b[n - 2] ^ b[n - 1] ^ b[0]) == a[n - 1] &&
        (b[n - 1] ^ b[0] ^ b[1]) == a[0]) {
      for (int i = 0; i < n; i++) {
        putchar_unlocked(b[i] == 0 ? 'S' : 'W');
      }
      putchar_unlocked(10);
      return 0;
    }
  }
  puts("-1");
}
