programming 27

버블정렬(Bubble Sort)

버블정렬은 옆에 있는 원소와 비교하여 더 작은 값을 계속해서 앞으로 보내는 것이다. [수행1] 1 10 5 8 7 6 4 3 2 9 --> 1과 10을 비교하고 1이 더 작기 때문에 넘어간다. 1 10 5 8 7 6 4 3 2 9 --> 1 5 10 8 7 6 4 3 2 9 --> 10과 5를 비교하고 5가 더 작기 때문에 앞으로 옮긴다. 1 5 10 8 7 6 4 3 2 9 --> 1 5 8 10 7 6 4 3 2 9 --> 10과 8을 비교하고 8이 더 작기 때문에 앞으로 옮긴다. 1 5 8 10 7 6 4 3 2 9 --> 1 5 8 7 10 6 4 3 2 9 --> 10과 7을 비교하고 7이 더 작기 때문에 앞으로 옮긴다. . . . 1 5 8 7 6 4 3 2 10 9 --> 1 5 8 7 6 ..

선택정렬(Selection Sort)

선택정렬은 가장 작은 것을 선택해서 제일 앞으로 보내는 것이다. 1 10 5 8 7 6 4 3 2 9 --> 가장 앞에 있는 1이 가장 작은 수이기 때문에 정렬이 이루어졌다. 1 10 5 8 7 6 4 3 2 9 --> 1 2 5 8 7 6 4 3 10 9 --> 나머지 9개의 수 중에 가장작은 수인 2와 10의 위치를 바꾼다. 1 2 5 8 7 6 4 3 10 9 --> 1 2 3 8 7 6 4 5 10 9 --> 나머지 8개의 수 중에 가장 작은 수인 3과 5의 위치를 바꾼다. 1 2 3 8 7 6 4 5 10 9 --> 1 2 3 4 7 6 8 5 10 9 --> 나머지 7개의 수 중에 가장 작은 수인 4와 8의 위치를 바꾼다. 1 2 3 4 7 6 8 5 10 9 --> 1 2 3 4 5 6 8 ..

백준(C) 1712번 손익분기점 풀이

C로 구현한 1712번 손익분기점 구하기 문제 풀이입니다. https://www.acmicpc.net/problem/1712 1712번: 손익분기점 월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 www.acmicpc.net #include int main() { int a, b, c; scanf("%d %d %d", &a, &b, &c); if(c

백준(C) 2292번 벌집 풀이

C로 구현한 2292번 벌집 구하기 문제 풀이입니다. https://www.acmicpc.net/problem/2292 2292번: 벌집 위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌 www.acmicpc.net #include int main() { int input, min=2, diff=5, count=2; scanf("%d", &input); if(input == 1){ printf("%d", input); return 0; } while(1){ if(input>=min && input

백준(C) 2941번 크로아티아 알파벳

C로 구현한 2941번 크로아티아 알파벳 구하기 문제 풀이입니다. https://www.acmicpc.net/problem/2941 2941번: 크로아티아 알파벳 예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다. 크로아티아 알파벳 변경 č c= ć c- dž dz= đ d- lj lj nj nj š s= ž z= www.acmicpc.net #include int main() { char input[101]; int count = 0; scanf("%s", input); for(int i=0; input[i]!='\0'; i++) { if(input[i] == 'c' || input[i]=='s' || input[i]=='z'){ ..

백준(C) 5622번 다이얼 풀이

C로 구현한 5622번 다이얼 구하기 문제 풀이입니다. https://www.acmicpc.net/problem/5622 5622번: 다이얼 첫째 줄에 알파벳 대문자로 이루어진 단어가 주어진다. 단어의 길이는 2보다 크거나 같고, 15보다 작거나 같다. www.acmicpc.net #include int main() { int num[] = {3,3,3,4,4,4,5,5,5,6,6,6,7,7,7,8,8,8,8,9,9,9,10,10,10,10}; char call[26]; int result = 0; scanf("%s", call); for(int i=0; call[i]!='\0'; i++) { result = result + num[call[i]-65] ; } printf("%d", result); } ..

백준(C) 2908번 상수 풀이

C로 구현한 2908번 상수 문제 풀이입니다. https://www.acmicpc.net/problem/2908 2908번: 상수 상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 www.acmicpc.net #include int main() { int num1, num2; scanf("%d %d", &num1, &num2); int result1 = ((num1%10)*100) + ((num1/10%10)*10) + (num1/100); int result2 = ((num2%10)*100) + ((num2/10%10)*10) + (num2/100); if(resul..

백준(C) 1152번 단어의 개수 풀이

C로 구현한 1152번 단어의 개수 구하기 문제 풀이입니다. https://www.acmicpc.net/problem/1152 1152번: 단어의 개수 첫 줄에 영어 대소문자와 띄어쓰기로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 띄어쓰기 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 www.acmicpc.net #include #include int main() { char input[1000001]; scanf("%[^\n]", input); int len = strlen(input), count=0; if(len == 1 && input[0] == ' '){ printf("0"); return 0; } for(int i=1; i

백준(C) 1157번 단어 공부 풀이

C로 구현한 1157번 단어 공부 문제 풀이입니다. #include int main() { char input[1000001]; int spell[26] = {0,}; int count=0; char num = '?'; scanf("%s", input); for(int i=0; input[i]!='\0'; i++) { if(input[i] >= 'a') input[i] = input[i] - 32; spell[input[i]-65]++; } for(int j=0; j count) { count = spell[j]; num = j; } else if(spell[j] == count) num = '?'; } if(num != '?') printf("%c", num+65); else printf("?"); }..