package main import ( "fmt" "bufio" "os" "strconv" ) func main() { n, _ := strconv.Atoi(readLine()) s := readLine() ans := false for i := 0; i <= n; i++ { for j := i + 1; j+j-i <= n; j++ { //fmt.Println(i, j) if s[i:j] == s[j:j+j-i] { ans = true j = n i = n } } } if ans { fmt.Println("YES") } else { fmt.Println("NO") } } var sc = bufio.NewScanner(os.Stdin) func nextLine() string { sc.Scan() return sc.Text() } func nextInt() int { i, _ := strconv.Atoi(nextLine()) return i } var rdr = bufio.NewReaderSize(os.Stdin, 1000000) func readLine() string { buf := make([]byte, 0, 1000000) for { l, p, e := rdr.ReadLine() if e != nil { panic(e) } buf = append(buf, l...) if !p { break } } return string(buf) }