BAEKJOON 133

[BOJ] 24060번 : 알고리즘 수업 - 병합 정렬1

🔒 문제 오늘도 서준이는 병합 정렬 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자. N개의 서로 다른 양의 정수가 저장된 배열 A가 있다. 병합 정렬로 배열 A를 오름차순 정렬할 경우 배열 A에 K 번째 저장되는 수를 구해서 우리 서준이를 도와주자. 크기가 N인 배열에 대한 병합 정렬 의사 코드는 다음과 같다. merge_sort(A[p..r]) { # A[p..r]을 오름차순 정렬한다. if (p < r) then { q

[BOJ] 25501번 : 재귀의 귀재

🔒 문제 정휘는 후배들이 재귀 함수를 잘 다루는 재귀의 귀재인지 알아보기 위해 재귀 함수와 관련된 문제를 출제하기로 했다. 팰린드롬이란, 앞에서부터 읽었을 때와 뒤에서부터 읽었을 때가 같은 문자열을 말한다. 팰린드롬의 예시로 AAA, ABBA, ABABA 등이 있고, 팰린드롬이 아닌 문자열의 예시로 ABCA, PALINDROME 등이 있다. 어떤 문자열이 팰린드롬인지 판별하는 문제는 재귀 함수를 이용해 쉽게 해결할 수 있다. 아래 코드의 isPalindrome 함수는 주어진 문자열이 팰린드롬이면 1, 팰린드롬이 아니면 0을 반환하는 함수다. #include #include int recursion(const char *s, int l, int r){ if(l >= r) return 1; else if(s..

[BOJ] 18870번 : 좌표 압축

🔒 문제 수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다. Xi를 좌표 압축한 결과 X&#39;i의 값은 Xi > Xj를 만족하는 서로 다른 좌표의 개수와 같아야 한다. X1, X2, ..., XN에 좌표 압축을 적용한 결과 X&#39;1, X&#39;2, ..., X&#39;N를 출력해보자. ⌨ 입력 첫째 줄에 N이 주어진다. 둘째 줄에는 공백 한 칸으로 구분된 X1, X2, ..., XN이 주어진다. 🖨 출력 첫째 줄에 X&#39;1, X&#39;2, ..., X&#39;N을 공백 한 칸으로 구분해서 출력한다. 📍 제한 1 ≤ N ≤ 1,000,000 -109 ≤ Xi ≤ 109 📚 예제 Ex1) 5 2 4 -10 4 -9 2 3 0 3 1 Ex2..

[BOJ] 10814번 : 나이순 정렬

🔒 문제 온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오. ⌨ 입력 첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000) 둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다. 나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다. 🖨 출력 첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력..

[BOJ] 1181번 : 단어 정렬

🔒 문제 알파벳 소문자로 이루어진 N개의 단어가 들어오면 아래와 같은 조건에 따라 정렬하는 프로그램을 작성하시오. 길이가 짧은 것부터 길이가 같으면 사전 순으로 ⌨ 입력 첫째 줄에 단어의 개수 N이 주어진다. (1 ≤ N ≤ 20,000) 둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다. 주어지는 문자열의 길이는 50을 넘지 않는다. 🖨 출력 조건에 따라 정렬하여 단어들을 출력한다. 단, 같은 단어가 여러 번 입력된 경우에는 한 번씩만 출력한다. 📚 예제 Ex1) 13 but i wont hesitate no more no more it cannot wait im yours i im it no but more wait wont yours cannot hesitate..

[BOJ] 11651번 : 좌표 정렬하기2

h2>🔒 문제 2차원 평면 위의 점 N개가 주어진다. 좌표를 y좌표가 증가하는 순으로, y좌표가 같으면 x좌표가 증가하는 순서로 정렬한 다음 출력하는 프로그램을 작성하시오. ⌨ 입력 첫째 줄에 점의 개수 N (1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N개의 줄에는 i번점의 위치 xi와 yi가 주어진다. (-100,000 ≤ xi, yi ≤ 100,000) 좌표는 항상 정수이고, 위치가 같은 두 점은 없다. 🖨 출력 첫째 줄부터 N개의 줄에 점을 정렬한 결과를 출력한다. 📚 예제 Ex1) 5 0 4 1 2 1 -1 2 2 3 3 1 -1 1 2 2 2 3 3 0 4 📌 풀이 파이썬 sorted 함수에서 정렬할때 고려할 것의 우선순위를 정할 수 있어서 그것을 사용해서 문제를 풀었다. key 인..

[BOJ] 11650번 : 좌표 정렬하기

🔒 문제 2차원 평면 위의 점 N개가 주어진다. 좌표를 x좌표가 증가하는 순으로, x좌표가 같으면 y좌표가 증가하는 순서로 정렬한 다음 출력하는 프로그램을 작성하시오. ⌨ 입력 첫째 줄에 점의 개수 N (1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N개의 줄에는 i번점의 위치 xi와 yi가 주어진다. (-100,000 ≤ xi, yi ≤ 100,000) 좌표는 항상 정수이고, 위치가 같은 두 점은 없다. 🖨 출력 첫째 줄부터 N개의 줄에 점을 정렬한 결과를 출력한다. 📚 예제 Ex1) 5 3 4 1 1 1 -1 2 2 3 3 1 -1 1 1 2 2 3 3 3 4 📌 풀이 파이썬 2차원 배열 입력 받는게 헷갈린다 리스트 선언 리스트에 append 이용해서 리스트 또 받음 => 한줄에 2개씩 값을..

[BOJ] 2108번 : 통계학

🔒 문제 수를 처리하는 것은 통계학에서 상당히 중요한 일이다. 통계학에서 N개의 수를 대표하는 기본 통계값에는 다음과 같은 것들이 있다. 단, N은 홀수라고 가정하자. 산술평균 : N개의 수들의 합을 N으로 나눈 값 중앙값 : N개의 수들을 증가하는 순서로 나열했을 경우 그 중앙에 위치하는 값 최빈값 : N개의 수들 중 가장 많이 나타나는 값 범위 : N개의 수들 중 최댓값과 최솟값의 차이 N개의 수가 주어졌을 때, 네 가지 기본 통계값을 구하는 프로그램을 작성하시오. ⌨ 입력 첫째 줄에 수의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 단, N은 홀수이다. 그 다음 N개의 줄에는 정수들이 주어진다. 입력되는 정수의 절댓값은 4,000을 넘지 않는다. 🖨 출력 첫째 줄에는 산술평균을 출력한다. 소..

[BOJ] 10989번 : 수 정렬하기3

🔒 문제 N개의 수가 주어졌을 때, 이를 오름차순으로 정렬하는 프로그램을 작성하시오. ⌨ 입력 첫째 줄에 수의 개수 N(1 ≤ N ≤ 10,000,000)이 주어진다. 둘째 줄부터 N개의 줄에는 수가 주어진다. 이 수는 10,000보다 작거나 같은 자연수이다. 🖨 출력 첫째 줄부터 N개의 줄에 오름차순으로 정렬한 결과를 한 줄에 하나씩 출력한다. 📚 예제 Ex1) 10 5 2 3 1 4 2 3 5 1 7 1 1 2 2 3 3 4 5 5 7 📌 풀이 처음에 sort함수 사용했는데 메모리 초과가 떴다. 그래서 구글링해보니 sort함수는 메모리 사용을 많이 한다고 한다. 그래서 계수 정렬을 이용했다. 계수 정렬은 주어지는 수의 범위가 작을때 사용하면 좋은 정렬로, 이 문제에서 자연수의 범위가 10000이하 이..

[BOJ] 1427번 : 소트인사이드

🔒 문제 배열을 정렬하는 것은 쉽다. 수가 주어지면, 그 수의 각 자리수를 내림차순으로 정렬해보자. ⌨ 입력 첫째 줄에 정렬하려고 하는 수 N이 주어진다. N은 1,000,000,000보다 작거나 같은 자연수이다. 🖨 출력 첫째 줄에 자리수를 내림차순으로 정렬한 수를 출력한다. 📚 예제 Ex1) 2143 4321 Ex2) 999998999 999999998 Ex3) 61423 64321 Ex4) 500613009 965310000 📌 풀이 주어진 수의 각 자리 수를 배열에 저장한 뒤 버블 소트를 사용했다 🔑 c언어 코드 #include #include #define SWAP(x,y,t)(t=x,x=y,y=t) int sort(int* ary, int N); void print(int* ary, int N..