Informatica Online Judge

  여기까지! 이제 그만~(설명) [0086 / 0056]

Time Limit(Test case) : 1000(ms)
Number of users who solved : 2210   Total Tried : 2348


The Champion of this Problem (C++) : kimtaeyoon49 - 0ms / 77byte
My Best Submission (C++) : N/A

[KOISTUDY (T. HS Jeon 2013)]




Background

1, 2, 3 ... 을 계속 더해나갈 때,
그 합이 입력한 정수보다 작을 동안(0 ~ 1000) 계속 더하는 프로그램을 작성해보자.

즉, 1부터 n까지 정수를 계속 더한다고 할 때,
어디까지 더해야 입력한 수보다 같거나 커지는지 알아보고자 하는 문제이다.

하지만, 이번에는 그 때의 합을 출력해야 한다.

예를 들어 57을 입력하면
1+2+3+...+8+9+10=55에 다시 11을 더해 66이 될 때,
그 값 66이 출력되어야 한다.


참고
조건문이나 반복문의 코드블록 안에서 break;가 실행되면
가장 가까운 반복 코드블록 구역의 밖으로 빠져나간다.


예시
int n, i, s=0;
scanf("%d", &n);
for(i=1; ; i++) //for 반목문에서 가운데의 조건이 빠진 경우 무한 반복된다.
{
  s+=i;
  if(s>=n)
    break; //참이면, 가장 가까운 반복 코드블록의 밖으로 빠져나간다.
} //break; 가 실행되면 반복을 중단하고 여기로 빠져 나온다.
printf("%d", s);

무한 반복이 되는 코드는
while(1) {...}, do {...}while(1); 등도 가능하다.
0이 아니면 모두 참(true)으로 인식되기 때문이다.


(C언어 기초 100제 v1.1)

Input

어느 정도까지 합을 계산할 지, 정수 한 개를 입력받는다.
단, 입력되는 자연수는 100,000,000이하이다.

Output

1, 2, 3, 4, 5 ... 계속 더해가다가,입력된 정수보다 커지거나 같아지는 경우,
그때까지의 합을 출력한다.

IO Example

입력
57

출력
66

Submit : [C/C++] | [C++11] | [Obj-C] | [Java] | [Python]
Prob Analysis : [Problem Statistics] | [Solution]