재밌는 문제 (while문) : 더하기 사이클
2020. 6. 23. 15:29
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
|
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
int num, fNum, sNum, newNum, prime, result;
// num : 입력받을 값, fNum : num의 십의자리수, sNum : num의 일의자리수
// prime : 원래의 num값 , result : num을 변환한 값
int count = 0; // 사이클 횟수
scanf("%d", &num);
prime = num;
while (1)
{
if (num < 10) // num의 값이 10 미만이면 앞 자리를 0으로, 뒷 자리를 그대로 num으로 설정
{
fNum = 0;
sNum = num;
}
else // num의 값이 10 이상이면 앞 자리는 num의 십의자리수, 뒷 자리는 num의 일의 자리수
{
fNum = num / 10;
sNum = num - (fNum * 10);
}
newNum = fNum + sNum; // 앞 자리와 뒷 자리를 더한 값
if (newNum < 10)
result = (sNum * 10) + newNum; // newNum이 한자릿수이면 newNum 그 자체가 일의 자릿수가 됨
else
result = (sNum * 10) + (newNum - ((newNum / 10) * 10)); // newNum이 두자릿수면 두자릿수값에서 일의자릿수값을 출
count++; // 사이클을 돌린 횟수
num = result; // num을 다시 result로 초기화
if (result == prime)
break;
}
printf("%d", count);
return 0;
}
|
cs |
개인적으로 재밌었던 문제인게.. 반복문을 돌릴 때 변수를 선언하는 위치가 아주 아주 중요하다는 걸 알게됐다.
코드를 몇 번 고쳤는 지도 모르겠다. 근데 맞았다고 뜨니까 정말 기뻤당
느낀 점
ⓛ일의 자리 표현은 % 10으로 간단하게 할 수 있는데도 저렇게 어렵게 한 걸 보니 나는 아직 갈 길이 먼 것 같다...
②다른 사람의 코드를 보니까 C 언어로도 정말 간결하게 짤 수가 있더라. 4~5줄 남짓한 코드였는데 깔끔하면서도 이해가 쉬운 코딩이였다. 나도 간결한 코딩을 지향하고 있지만, 아직은 실력이 못 받쳐주는 것 같다. 더 분발해야겠다.
'공부 > C' 카테고리의 다른 글
배열을 이용한 문제풀이 (0) | 2020.06.26 |
---|---|
문자열 1 (0) | 2020.06.24 |
~06.18 까지의 공부 일지 - 포인터 (0) | 2020.06.19 |
배열 프로그래밍 예제 마지막 문제 학습 (0) | 2020.06.10 |