mang_dev
맹꽁거리는 개발자
mang_dev
전체 방문자
오늘
어제
  • 분류 전체보기 (185)
    • Frontend (2)
      • Next.js (1)
    • Backend (3)
      • GraphQL (2)
    • Book (1)
      • 기타 (1)
    • Old (177)
      • 알고리즘 퍼즐 (1)
      • 백준 (131)
      • 프로그래머스 (0)
      • Codility (15)
      • LeetCode (7)
      • Codewars (1)
      • Codeforces (0)
      • Django (6)
      • React (2)
      • Naver Map Api (3)
      • Web UI (4)
      • Introduction to Cloud (2)
hELLO · Designed By 정상우.
mang_dev

맹꽁거리는 개발자

백준 10972번 다음 순열 // C++
Old/백준

백준 10972번 다음 순열 // C++

2020. 3. 5. 22:55

문제

 

1부터 N까지의 수로 이루어진 순열이 있다. 이때, 사전순으로 다음에 오는 순열을 구하는 프로그램을 작성하시오.

사전 순으로 가장 앞서는 순열은 오름차순으로 이루어진 순열이고, 가장 마지막에 오는 순열은 내림차순으로 이루어진 순열이다.

N = 3인 경우에 사전순으로 순열을 나열하면 다음과 같다.

  • 1, 2, 3
  • 1, 3, 2
  • 2, 1, 3
  • 2, 3, 1
  • 3, 1, 2
  • 3, 2, 1

입력

첫째 줄에 N(1 ≤ N ≤ 10,000)이 주어진다. 둘째 줄에 순열이 주어진다.

출력

첫째 줄에 입력으로 주어진 순열의 다음에 오는 순열을 출력한다. 만약, 사전순으로 마지막에 오는 순열인 경우에는 -1을 출력한다.

 


 

풀이

 

next_permutation을 이용하여, 다음 순열이 존재한다면 해당 순열을 존재하지 않는다면 -1을 출력하면 된다.

 

다음 순열이 존재할 경우, next_permutation 함수는 true를 리턴하기 때문에 이 경우에만 출력해주면 된다.

 


 

코드

더보기
#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;

int main() {
	int n;
	cin >> n;

	vector<int> v;
	for (int i = 0; i < n; i++) {
		int input;
		cin >> input;

		v.push_back(input);
	}

	if (next_permutation(v.begin(), v.end())) {
		for (int i = 0; i < n; i++) {
			printf("%d ", v[i]);
		}
	}
	else
		printf("-1\n");

	return 0;
}
저작자표시 (새창열림)

'Old > 백준' 카테고리의 다른 글

백준 10974번 모든 순열 // C++  (0) 2020.03.05
백준 10973번 이전 순열 // C++  (0) 2020.03.05
백준 10971번 외판원 순회(2) // C++  (0) 2020.03.05
백준 11286번 절댓값 힙 // C++  (0) 2020.03.04
백준 11047번 동전 0 // C++  (0) 2020.03.04
    'Old/백준' 카테고리의 다른 글
    • 백준 10974번 모든 순열 // C++
    • 백준 10973번 이전 순열 // C++
    • 백준 10971번 외판원 순회(2) // C++
    • 백준 11286번 절댓값 힙 // C++
    mang_dev
    mang_dev

    티스토리툴바