1. 1부터 100사이의 모든 3의 배수의 합을 계산하여 출력하는 프로그램을 다음의 3가지 반복구조를 사용하여 작성하라.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | #include <stdio.h> int main(void) { int x = 1, sum = 0; // while 루프 while (x <= 100) { if (x % 3 == 0) sum += x; x++; } // for 루프 sum = 0; for (x = 1; x <= 100; x++) { if (x % 3 == 0) sum += x; } // do...while 루프 x = 1; sum = 0; do { if (x % 3 == 0) sum += x; x++; } while (x <= 100); printf("[while 루프문] 1~100사이의 모든 3의배수의 합은 %d 입니다\n", sum); printf("[for 루프문] 1~100사이의 모든 3의배수의 합은 %d 입니다\n", sum); printf("[do...while 루프문] 1~100사이의 모든 3의배수의 합은 %d 입니다\n", sum); return 0; } | cs |
[OUTPUT]
2. 반복 루프는 파일의 끝을 만날 때까지 자료를 처리하는데 많이 사용된다. 표준 입력에서는 사용자가 Ctrl + Z 를 입력하면 파일의 끝으로 간주한다. scanf()가 Ctrl + Z를 만나면 EOF를 반환한다. 사용자가 Ctrl + Z를 누르기 전까지, 입력한 정수의 합을 계산하여 출력하는 프로그램을 작성하여 테스트하라.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | #include <stdio.h> int main(void) { int x,sum=0; while (scanf("%d ", &x) != EOF) { sum += x; } printf("정수의 핪은 %d 입니다\n", sum); return 0; } | cs |
[OUTPUT]
3. 반복 루프를 사용하여 다음과 같은 패턴을 출력하는 프로그램을 작성하라.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | #include <stdio.h> int main(void) { int i, j,x; for (i = 1; i <= 7; i++) { for (x = 7-i; x >0 ; x--) { printf(" "); } for ( j = 1; j <= i; j++) { printf("*"); } printf("\n"); } return 0; } | cs |
[OUTPUT]
4. 중첩 반복문을 사용하여서 다음과 같이 출력하는 프로그램을 작성하여 보자.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | #include <stdio.h> int main(void) { int x, i, j; printf("정수를 입력하시오: "); scanf("%d", &x); for (i = 1; i <= x; i++) { for (j = 1; j <= i; j++) { printf("%d", j); } printf("\n"); } return 0; } | cs |
[OUTPUT]
5. 가끔은 일정한 시간 동안 아무 일도 하지 않으면서 시간을 지연시킬 목적으로 반복문을 사용하기도 한다. 사용자에게서 하나의 수를 입력받아서 변수에 저장한다. 반복문을 사용하여 이 변수의 값을 1씩 감소시키면서 이 변수의 값이 0이 될 때까지 반복한다. 반복이 끝나면 벨소리를 낸다.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | #include <stdio.h> int main(void) { int x, i; printf("카운터의 초기값을 입력하시오: "); scanf("%d", &x); for (i = x; i > 0; i--) { printf("%d ", i); } printf("\n\a"); return 0; } | cs |
[OUTPUT]
6. 앞장에서 간단한 정수 계산기를 만들어본 적이 있다. 이 계산기 프로그램에 메뉴를 추가하도록 한다. 다음과 같은 메뉴를 화면에 출력하고 사용자가 메뉴 중에서 하나를 선택할 때까지 반복을 계속한다. do...while 반복문을 사용하여 사용자가 적절한 선택을 했는지를 검사하도록 하라. 만약 사용자가 A, S, M, D, Q가 아닌 다른 문자를 입력하면 "연산을 선택하시요:" 메시지를 계속해서 출력한다. 하나의 메뉴가 선택되면 해당되는 연산을 실행하고 다시 메뉴를 선택할 수 있도록 하라. 반복을 종료하는 메뉴인 Q는 break 문을 이용하여 다시 구현하도록 하라.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | #include <stdio.h> int main(void) { int x, y; char ch; printf("************************\n"); printf("A---- Add\n"); printf("S---- Subtract\n"); printf("M---- Multiply\n"); printf("D---- Divide\n"); printf("Q---- Quit\n"); printf("************************\n"); do { printf("연산을 선택하시오: "); scanf(" %c", &ch); if (ch == 'Q') break; printf("두 수를 공백으로 분리하여 입력하시오: "); scanf("%d %d", &x, &y); if (ch == 'A') { printf("연산의 결과는 %d 입니다\n", x + y); continue; } else if (ch == 'S') { printf("연산의 결과는 %d 입니다\n", x - y); continue; } else if (ch == 'M') { printf("연산의 결과는 %d 입니다\n", x * y); continue; } if (ch == 'D') { printf("연산의 결과는 %d 입니다\n", x / y); continue; } } while (1); return 0; } | cs |
[OUTPUT]
7. 2와 100 사이에 있는 모든 소수(prime number)를 찾는 프로그램을 작성하라. 정수가 소수가 되려면 1과 자기 자신만을 약수로 가져야 한다.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | #include<stdio.h> int main(void) { int i, j; for (i = 2; i <= 100; i++) { for (j = 2; j <= i - 1; j++) { if (i % j == 0) break; } if (i == j) printf("%d ", i); } printf("\n"); return 0; } | cs |
[OUTPUT]
8. 컴퓨터는 막대 그래프를 그리는 데도 사용된다. 사용자로부터 1부터 50사이의 숫자를 입력받아서 숫자만큼의 별표를 출력하는 프로그램을 작성하라. 막대는 세로로 그려지게 된다.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | #include<stdio.h> int main(void) { int x = 0; int i, y = 0; while (x >= 0) { printf("막대의 높이(종료: -1): "); scanf("%d", &x); for (i = 0; i <= x; i++) { printf("*"); } printf("\n"); } return 0; } | cs |
[OUTPUT]
9. (1+2+3+...+n)가 10000을 넘지 않으면서 가장 큰 값과 그 때의 n의 값을 구하라.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | #include <stdio.h> int main(void) { int i, j, sum = 0; for (i = 1;; i++) { sum += i; if (sum > 10000) { j = i - 1; sum -= i; break; } } printf("1부터 %d까지의 합이 %d입니다.", j, sum); return 0; } | cs |
[OUTPUT]
10. 실수의 거듭 제곱값을 계산하는 프로그램을 작성하여 보자. 사용자로부터 하나의 실수 r와 거듭 제곱 횟수를 나타내는 정수 n을 입력받아서 을 구하여 화면에 출력한다.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | #include <stdio.h> int main(void) { double r, n, result = 1.0; printf("실수의 값을 입력하시요: "); scanf("%lf", &r); printf("거듭제곱횟수를 입력하시오:"); scanf("%lf", &n); while (n != 0) { result *= r; n--; } printf("결과값은 %lf", result); return 0; } | cs |
[OUTPUT]
11. 의 값을 계산하여 출력하여 보자.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | #include <stdio.h> int main(void) { int i, x; int result = 0; printf("n의 값을 입력하시오: "); scanf("%d", &x); for (i = 1; i <= x; i++) { result += i * i; } printf("계산값은 %d입니다.\n", result); return 0; } | cs |
[OUTPUT]
12. 피보나치 수열은 다음과 같이 정의되는 수열이다.
피보나치 수열에선느 앞의 2개의 원소를 합하여 뒤의 원소를 만든다. 피보나치 수열은 컴퓨터에서도 탐색 문제 등에 사용되기도 한다. 피보나치 수열을 생성하여 출력하는 프로그램을 작성하여 보자.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | #include <stdio.h> int main(void) { int n, c,i, a = 0, b = 1; printf("몇 번째 항까지 구할까요? "); scanf("%d", &n); printf("0 1"); for (i = 0; i < n-1; i++) { c = a + b; printf(" %d", c); a = b; b = c; } return 0; } | cs |
[OUTPUT]
13. 서로 다른 n개에서 r개를 택하여 일렬로 나열하는 방법의 수를 순열(permutation)이라 하고, 로 표시한다. 순열은 다음과 같은 식을 이용하여 구할 수 있다. 순열을 구하는 프로그램을 작성하라. n과 r은 사용자가 입력할 수 있도록 하라
= n(n-1)(n-2)(n-r+1)
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | #include <stdio.h> int main(void) { int i, n, r, P = 1; printf("n의 값: "); scanf("%d", &n); printf("r의 값: "); scanf("%d", &r); for (i = n; i >= n - (r + 1); i--) { P *= i; } printf("순열의 값은 %d 입니다", P); return 0; } | cs |
[OUTPUT]
14. 사용자가 입력한 ㅌ특정한 정수의 자리수를 반대로 출력하는 프로그램을 작성하라. 예를 들어서 사용자가 정수 1206을 입력하였다면 6021이 출력되어야 한다/ 만약 음수를 입력하면 오류 메시지를 출력하라. do...while 문을 사용하여 보라.
[CODE]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | #include <stdio.h> int main(void) { int n, a, b, c, d; printf("정수를 입력하시오: "); scanf("%d", &n); do { if (n < 0) break; a = n % 10; b = (n / 10) % 10; c = (n / 100) % 10; d = (n / 1000) % 10; printf("%d%d%d%d", a, b, c, d); break; } while (1); return 0; } | cs |
[OUTPUT]
'프로그래밍 > c/c++' 카테고리의 다른 글
[C] 쉽게 풀어쓴 C EXPRESS 제 6장 Programming 문제 풀이 (0) | 2018.11.19 |
---|---|
[C] 쉽게 풀어쓴 C EXPRESS 제 5장 Programming 문제 풀이 (1) | 2018.11.18 |
[C] 쉽게 풀어쓴 C EXPRESS 제 4장 Programming 문제 풀이 (0) | 2018.11.16 |
[C] 쉽게 풀어쓴 C EXPRESS 제 3장 Programming 문제 풀이 (0) | 2018.11.16 |
[C] 쉽게 풀어쓴 C EXPRESS 제 2장 Programming 문제 풀이 (0) | 2018.11.16 |