Algorithm
baekjoon 1065 한수
Hans_S_92
2022. 6. 13. 23:09
문제
어떤 양의 정수 X의 각 자리가 등차수열을 이룬다면, 그 수를 한수라고 한다. 등차수열은 연속된 두 개의 수의 차이가 일정한 수열을 말한다. N이 주어졌을 때, 1보다 크거나 같고, N보다 작거나 같은 한수의 개수를 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 1,000보다 작거나 같은 자연수 N이 주어진다.
출력
첫째 줄에 1보다 크거나 같고, N보다 작거나 같은 한수의 개수를 출력한다.
예제 입력 1 복사
110
예제 출력 1 복사
99
예제 입력 2 복사
1
예제 출력 2 복사
1
예제 입력 3 복사
210
예제 출력 3 복사
105
예제 입력 4 복사
1000
예제 출력 4 복사
144
예제 입력 5 복사
500
예제 출력 5 복사
119
풀이
입력 > 1000보다 작거나 같은 X
출력 > 1에서부터 X까지의 각 자리수에 대해여 등차 수열을 가지는 수의 갯수
조건 >
1) 10 미만의 자연수는 할 필요가 없다.? -> 1~9 까지는 길이가 1인 등차 수열이다. ( 예체 출력 2보고 유추 )
2) 10 ~ 99 까지도 등차 수열이다.
3) 100부터 시작한다.
4) 1번자리수 - 2번자리수 == 2번자리수 - 3반자리수 이어야 한다.
5) 1번자리수 - 2번자리수 == 2번자리수 - 3번자리수 && 2번자리수 - 3번자리수 == 3번자리수 - 4번자리수
#include <stdio.h>
int checkHansoo(int n)
{
int tempList[4] = { 0, };
int tempNum = n;
int count = 0;
int i=0;
while(tempNum / 10 != 0) {
count++;
tempList[i] = tempNum % 10;
tempNum = tempNum / 10;
i++;
}
tempList[i] = tempNum % 10;
if(count == 2) {
if( (tempList[0] - tempList[1]) == (tempList[1] - tempList[2]))
return 1;
else
return 0;
}
if( count == 3 ) {
if( (tempList[0] - tempList[1]) == (tempList[1] - tempList[2]) &&
(tempList[1] - tempList[2])== (tempList[2] - tempList[3]))
return 1;
else
return 0;
}
}
int main() {
int getNum = 0;
int result = 0;
int i;
scanf("%d", &getNum);
if( getNum < 100)
result = getNum;
else {
result = 99;
for(i=100;i<=getNum;i++) {
if(checkHansoo(i))
result++;
}
}
printf("%d\n", result);
return 0;
}