목록분류 전체보기 (65)
아무거나 내꺼 공부할래
▣ 문제 - N개의 마구간이 1차원 수직선상에 있습니다. 각 마구간은 x1, x2, x3, ......, xN의 좌표를 가 지며, 마구간간에 좌표가 중복되는 일은 없습니다. 현수는 C마리의 말을 가지고 있는데, 이 말들은 서로 가까이 있는 것을 좋아하지 않습니다. 각 마구간에는 한 마리의 말만 넣을 수 있고, 가장 가까운 두 말의 거리가 최대가 되게 말을 마구간에 배치하고 싶습니다. C마리의 말을 N개의 마구간에 배치했을 때 가장 가까운 두 말의 거리가 최대가 되는 그 최대 값을 출력하는 프로그램을 작성하세요. ▣ 입력설명 - 첫 줄에 자연수 N(3
보호되어 있는 글입니다.
▣ 문제 지니레코드에서는 불세출의 가수 조영필의 라이브 동영상을 DVD로 만들어 판매하려 한다. DVD에는 총 N개의 곡이 들어가는데, DVD에 녹화할 때에는 라이브에서의 순서가 그대로 유지 되어야 한다. 순서가 바뀌는 것을 우리의 가수 조영필씨가 매우 싫어한다. 즉, 1번 노래와 5번 노래를 같은 DVD에 녹화하기 위해서는 1번과 5번 사이의 모든 노래도 같은 DVD에 녹화해야 한다. 지니레코드 입장에서는 이 DVD가 팔릴 것인지 확신할 수 없기 때문에 이 사업에 낭비되는 DVD를 가급적 줄이려고 한다. 고민 끝에 지니레코드는 M개의 DVD에 모든 동영상을 녹화하기 로 하였다. 이 때 DVD의 크기(녹화 가능한 길이)를 최소로 하려고 한다. 그리고 M개의 DVD는 모두 같은 크기여야 제조원가가 적게 들..
▣ 입력설명 임의의 N개의 숫자가 입력으로 주어집니다. N개의 수를 오름차순으로 정렬한 다음 N개의 수 중 한 개의 수인 M이 주어지면 이분검색으로 M이 정렬된 상태에서 몇 번째에 있는지 구하는 프로그램을 작성하세요. ▣ 입력설명 - 첫 줄에 한 줄에 자연수 N(3 0 1 2 3 4, lt 5, mid 6 7, rt 12 23 32 57 65 81 87 99 만약 m보다 작다면 반드시 num[mid]보다 왼쪽에 있기 때문에 rt를 mid-1의 자리로 바꿔준다 0, lt 1, mid 2,rt 3 4 5 6 7 12 23 32 57 65 81 87 99 num[mid]가 m과 같을때 break문을 걸어주고 출력값은 배열의 위치 이기 때문에 mid+1이 된다.
▣ 문제 입력으로 양의 정수 N이 입력되면 2개 이상의 연속된 자연수의 합으로 정수 N을 표현하는 방 법의 가짓수를 출력하는 프로그램을 작성하세요. 만약 N=15이면 7+8=15 4+5+6=15 1+2+3+4+5=15 와 같이 총 3가지의 경우가 존재한다. ▣ 입력설명 - 첫 번째 줄에 양의 정수 N(7= 1; j--) { sum = sum + j; temp[p1++] = j; if (sum == n) { cnt++; break; } } if (sum == n) { for (j = p1 - 1; j > 0; j--) { printf("%d + ", temp[j]); } printf("%d = %d\n", temp[0], n); } } printf("%d\n", cnt); return 0; } 어떤 정수를..
보호되어 있는 글입니다.
보호되어 있는 글입니다.
▣ 문제 두 집합 A, B가 주어지면 두 집합의 교집합을 출력하는 프로그램을 작성하세요. ▣ 입력설명 - 첫 번째 줄에 집합 A의 크기 N(1 temp) arr2[j + 1] = arr2[j]; else break; } arr2[j + 1] = temp; } while (p1 < n && p2 < m) { if (arr1[p1] == arr2[p2]) { res[p3++] = arr1[p1]; p1++; p2++; } else if (arr1[p1] < arr2[p2]) { p1++; } else p2++; } for (i = 0; i < p3; i++) printf("%d ", res[i]); return 0; } 우선, arr1과 arr2를 삽입정렬로 오름차순으로 정렬을 한다. 만약 입력 예시를 예로..