[BOJ / C++] 비밀 이메일 (문자열)

2025. 8. 28. 22:02·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/2999

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

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

    string s;
    cin >> s;

    int n = s.size();

    int r = 1, c = s.size();
    
    for (int i = 1; i*i <= s.size(); i++) {
        if (n % i == 0 && i <= n/i) {
            r = i;
            c = n/i;
        }
    }

    vector<vector<char>> board(r, vector<char>(c));
    int idx = 0;
    for (int j = 0; j < c; j++) {
        for (int i = 0; i < r; i++) {
            board[i][j] = s[idx];
            idx++; 
        }
    }

    for (int i = 0; i < r; i++) {
        for (int j = 0; j < c; j++) {
            cout << board[i][j];
        }
    }
}

 

 

2. 시간복잡도

보드에 문자열을 넣는 것이 가장 오래걸리는데 O(rc)이다. n = 100이므로 O(rc) = 50 * 50 = 2,500 <= 10^8 이므로 시간제한 1초 내에 통과 가능하다.

 

 

3. 분석

r, c를 찾아내는 것이 가장 핵심이다. (r<=c && r*c ==n)을 만족시켜야한다.

 

i * i <= n까지 돌면서 n%i == 0 && i <= n/i 인 것을 찾으면 된다. n%i==0이어야 r이 될 수 있고, n/i가 c가 될 값이기 때문이다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 구슬 찾기 (그래프)  (0) 2025.09.09
[BOJ / C++] 주사위 굴리기 (시뮬레이션)  (0) 2025.09.01
[BOJ / C++] 이분 그래프 (그래프)  (0) 2025.08.20
[BOJ 11403 / C++] 경로 찾기 (그래프)  (0) 2025.08.17
[BOJ 1197 / C++] 최소 스패닝 트리 (최소 신장 트리)  (0) 2025.08.15
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 구슬 찾기 (그래프)
  • [BOJ / C++] 주사위 굴리기 (시뮬레이션)
  • [BOJ / C++] 이분 그래프 (그래프)
  • [BOJ 11403 / C++] 경로 찾기 (그래프)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (172) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
      • 코딩테스트 (95) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (12) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 비밀 이메일 (문자열)
상단으로

티스토리툴바