Post

[BaekJoon] 1213번 - 팰린드롬 만들기 [Java][C++]

[BaekJoon] 1213번 - 팰린드롬 만들기 [Java][C++]

문제 링크


1. 문제 풀이


주어진 문자열로 사전순으로 앞서는 팰린드롬을 만드는 문제로 팰린드롬은 길이가 짝수면 모든 문자가 짝수개 존재해야하고, 길이가 홀수면 홀수개 존재하는 문자가 1종류며 나머지 문자는 모두 짝수개 존재해야한다. 알파벳에 대한 카운팅 배열을 통해 각 문자의 개수를 세주고 홀수일때 짝수일때 분기처리해서 구현하면 된다.


2. 코드


1. 풀이 [Java]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import java.io.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();

        String str = br.readLine();

        int[] cnt = new int[26];
        for (char c : str.toCharArray()) {
            cnt[c - 'A']++;
        }

        boolean flag = true;
        if (str.length() % 2 == 0) {
            for (int x : cnt) {
                if (x % 2 == 1) {
                    flag = false;
                    break;
                }
            }
        } else {
            int oddCnt = 0;
            for (int x : cnt) {
                if (x % 2 == 1) {
                    oddCnt++;
                }
            }

            if (oddCnt != 1) {
                flag = false;
            }
        }

        if (flag) {
            for (int i = 0; i < 26; i++) {
                if (cnt[i] > 0) {
                    sb.append(String.valueOf((char) (i + 'A')).repeat(cnt[i] / 2));
                }
            }
            for (int i = 0; i < 26; i++) {
                if (cnt[i] % 2 == 1) {
                    sb.append((char) (i + 'A'));
                    break;
                }
            }
            for (int i = 25; i >= 0; i--) {
                if (cnt[i] > 0) {
                    sb.append(String.valueOf((char) (i + 'A')).repeat(cnt[i] / 2));
                }
            }
            System.out.println(sb);
        } else {
            System.out.println("I'm Sorry Hansoo");
        }
    }
}


2. 풀이 [C++]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include <bits/stdc++.h>
using namespace std;

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);

    string s;
    cin >> s;

    vector<int> cnt(26);
    for (char c : s) {
        cnt[c - 'A']++;
    }

    bool flag = true;
    if (s.size() % 2) {
        int oddCnt = 0;
        for (int x : cnt) {
            if (x % 2 == 1) oddCnt++;
        }

        if (oddCnt != 1) flag = false;
    } else {
        for (int x : cnt) {
            if (x % 2 == 1) {
                flag = false;
                break;
            }
        }
    }

    if (flag) {
        for (int i = 0; i < 26; i++) {
            if (cnt[i]) {
                cout << string(cnt[i] / 2, (i + 'A'));
            }
        }
        for (int i = 0; i < 26; i++) {
            if (cnt[i] % 2) {
                cout << (char)(i + 'A');
                break;
            }
        }
        for (int i = 25; i >= 0; i--) {
            if (cnt[i]) {
                cout << string(cnt[i] / 2, (i + 'A'));
            }
        }
    } else {
        cout << "I'm Sorry Hansoo";
    }
}

This post is licensed under CC BY 4.0 by the author.