목록Study/Algorithm (400)
hwooo
https://www.acmicpc.net/problem/2581 2581번: 소수 M이상 N이하의 자연수 중 소수인 것을 모두 찾아 첫째 줄에 그 합을, 둘째 줄에 그 중 최솟값을 출력한다. 단, M이상 N이하의 자연수 중 소수가 없을 경우는 첫째 줄에 -1을 출력한다. www.acmicpc.net 코드 #include int main() { int M, N, i, num, sum = 0, min=0; scanf("%d%d", &M, &N); for (i = M; i
https://www.acmicpc.net/problem/1978 1978번: 소수 찾기 첫 줄에 수의 개수 N이 주어진다. N은 100이하이다. 다음으로 N개의 수가 주어지는데 수는 1,000 이하의 자연수이다. www.acmicpc.net 코드 #include int IsPrime(int n); int main() { int N, i, num, sum=0; scanf("%d", &N); for (i = 0; i < N; i++) { scanf("%d", &num); sum+=IsPrime(num); } printf("%d", sum); return 0; } int IsPrime(int n) { int i; if (n == 1) return 0; for (i = 2; i < n; i++) { if (n..
https://www.acmicpc.net/problem/10250 10250번: ACM 호텔 프로그램은 표준 입력에서 입력 데이터를 받는다. 프로그램의 입력은 T 개의 테스트 데이터로 이루어져 있는데 T 는 입력의 맨 첫 줄에 주어진다. 각 테스트 데이터는 한 행으로서 H, W, N, 세 정수 www.acmicpc.net 코드 #include int main(void) { int T, H, W, N; int i, room_H, room_W, room; scanf("%d", &T); for (i = 0; i < T; i++) { scanf("%d%d%d", &H, &W, &N); room_W = N / H; if (N%H == 0) room_H = H; else room_H = N - room_W * H..
https://www.acmicpc.net/problem/2839 2839번: 설탕 배달 상근이는 요즘 설탕공장에서 설탕을 배달하고 있다. 상근이는 지금 사탕가게에 설탕을 정확하게 N킬로그램을 배달해야 한다. 설탕공장에서 만드는 설탕은 봉지에 담겨져 있다. 봉지는 3킬로그 www.acmicpc.net 풀이 적은 개수의 봉지를 옮겨야 하므로 5kg의 봉지를 먼저 계산했다.N이 나오지 않은 경우에는 5kg 봉지의 갯수를 줄여서 무게를 맞췄고, 5kg 봉지의 갯수가 음수가 되었을 경우 N이 나올 수 없으므로 -1을 출력했다. 코드 #include int main() { int N, a, b = 0, sum; scanf("%d", &N); // N=5*a+3*b a = N / 5; while (1) { if (..
https://www.acmicpc.net/problem/2292 2292번: 벌집 위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌 www.acmicpc.net 풀이 1 : 1번, 2~7: 2번, 8~19: 3번, 20~37: 4번, 38~61: 5번... 이런 식으로 2부터 6의 배수만큼 값이 올라간다. 코드 #include int main() { int N, i = 0, sum = 2; scanf("%d", &N); while (sum
https://www.acmicpc.net/problem/1712 1712번: 손익분기점 월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 www.acmicpc.net 풀이 반복문으로 아무리 조건을 추가해도 시간초과가 뜨길래 결국 검색해보았다.반복문을 써야만 한다고 생각했는데, 식을 정리한 후에 코드를 짜면 간단하다는 걸 배웠다. 코드 #include #include int main() { int A, B, C; scanf("%d %d %d", &A, &B, &C); if (B >= C) printf("-1"); // 손익분기점 존재 X else printf("%d"..
https://www.acmicpc.net/problem/1316 1316번: 그룹 단어 체커 그룹 단어란 단어에 존재하는 모든 문자에 대해서, 각 문자가 연속해서 나타나는 경우만을 말한다. 예를 들면, ccazzzzbb는 c, a, z, b가 모두 연속해서 나타나고, kin도 k, i, n이 연속해서 나타나기 때 www.acmicpc.net 풀이 알파벳이 나온 횟수가 1 이상이고, 해당 알파벳 바로 전 알파벳이 같지 않은 경우에는 반복문을 중단했다. 문자열의 끝까지 확인한 경우에만 그룹 단어를 세는 방식으로 코드를 구현했다. 코드 #include int main() { char word[101]; int N, i, j, flag, cnt = 0, atoz[26] = { 0, }; scanf("%d", ..
https://www.acmicpc.net/problem/2941 2941번: 크로아티아 알파벳 예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다. 크로아티아 알파벳 변경 č c= ć c- dž dz= đ d- lj lj nj nj š s= ž z= www.acmicpc.net 풀이 알파벳 하나당 갯수를 세며, 2자리 혹은 3자리의 문자가 나올 땐 i 값을 증가하여 카운트 되지 않게 했다. 코드 #include int main() { char word[101]; int i = 0, cnt = 0; scanf("%s", &word); while (word[i] != NULL) { if (word[i] == 'c') { if (word[..