NLP Learner in Switzerland

[C] 백준 단계별로 풀어보기 4단계 while문 3문제 본문

Algorithm in C/백준 알고리즘

[C] 백준 단계별로 풀어보기 4단계 while문 3문제

초코빵 2021. 4. 11. 10:00
728x90
반응형

* 문제번호를 클릭하면 해당 문제로 이동합니다(새창)

 

 

 

10952 A+B-5

#include <stdio.h>

int main() {
    int A, B;
    while (1) {
        scanf("%d %d", &A, &B);
        if (A == 0 && B == 0) {
            break;
        }
        printf("%d\n", A + B);
    }
    return 0;
}

- 특정 조건을 만족할 때까지 계속 입력받으려면 while (1) + if (조건) break 조합으로 사용하면 된다. 

 

 

 

 

10951 A+B-4

 

*** 잘못된 풀이

#include <stdio.h>

int main() {
    int A, B;
    while (scanf("%d %d", &A, &B)==1) {
        printf("%d\n", A + B);
    }
    return 0;
}

- 계속 입력 받는다길래 while문에다가 예전에 어디선가 배웠던 scanf == 1을 넣으면 되겠군 했으나 원하는 결과가 안 나온다.

- 모르겠어서 찾아보니 EOF(End Of File)라는 명령어를 쓴 예시들이 많았다.

- EOF = 파일 끝 = 입력이 없으면 종료

*** 올바른 풀이

#include <stdio.h>

int main() {
    int A, B;
    while (scanf("%d %d", &A, &B)!=EOF) {
        printf("%d\n", A + B);
    }
    return 0;
}

 

 

 

1110 더하기 사이클

#include <stdio.h>

int main() {
    int inputNumber, tens, units, sum, newvalue = -1, length = 0;
    scanf("%d", &inputNumber);
    int result = inputNumber;
    while (result != newvalue) {
        tens = inputNumber / 10;
        units = inputNumber % 10;
        sum = (tens + units) % 10;
        newvalue = 10 * units + sum;
        inputNumber = newvalue;
        length++;
    }
    printf("%d", length);
}

- 헷갈려서 변수명을 좀 길게 썼다. tens : 10의자리 / units : 1의자리 / sum : 10의자리 수와 1의자리 수 합

- newvalue : 새로 구해지는 숫자(주어진 수의 가장 오른쪽 자리 수와 앞에서 구한 합의 가장 오른쪽 자리 수를 이어 붙인 것)

- length : 길이를 반환하라고 했으므로

 

- inputNumber가 계속 바뀌면 안되므로 다른 변수(result)에 넣어주어서 while문에서 비교할 수 있게 했다.

 

 

 

 

Comments