1, 2, 3 ... 을 순서대로 계속 더해나갈 때,
그 합이 입력한 정수보다 작을 동안만 계속 더하는 프로그램을 작성해보자.
즉, 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)으로 인식되기 때문이다.
728x90
반응형
https://codeup.kr/problem.php?id=1087
[기초-종합] 여기까지! 이제 그만~(설명)
C언어기초100제v1.2 : @컴퓨터과학사랑, 전국 정보(컴퓨터)교사 커뮤니티/연구회 - 학교 정보(컴퓨터)선생님들과 함께 수업/방과후학습/동아리활동 등을 통해 재미있게 배워보세요. - 모든 내용
codeup.kr
문제 분류 : 기초4-1. 단순 반복문
문제 설명
입력
언제까지 합을 계산할 지, 정수 1개를 입력받는다.
단, 입력되는 자연수는 100,000,000이하이다.
출력
1, 2, 3, 4, 5 ... 순서대로 계속 더해가다가, 그 합이 입력된 정수보다 커지거나 같아지는 경우,
그때까지의 합을 출력한다.
입력 예시
57
출력 예시
66
도움말
내 답안
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
public class Main {
public static void main(String[] args) throws IOException { // BufferdReader, BufferedWriter
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int num = Integer.parseInt(br.readLine());
int sum = 0;
for(int i=1; sum<num; i++) {
sum += i;
}
bw.write(String.valueOf(sum));
bw.flush();
bw.close();
br.close();
}
}
728x90
반응형
'알고리즘 > [코드업] 기초 100제' 카테고리의 다른 글
[JAVA] CodeUp 1089 : [기초-종합] 수 나열하기1 (0) | 2021.07.31 |
---|---|
[JAVA] CodeUp 1088 : [기초-종합] 3의 배수는 통과?(설명) (0) | 2021.07.31 |
[JAVA] CodeUp 1086 : [기초-종합] 그림 파일 저장용량 계산하기(설명) (0) | 2021.07.31 |
[JAVA] CodeUp 1085 : [기초-종합] 소리 파일 저장용량 계산하기(설명) (0) | 2021.07.31 |
[JAVA] CodeUp 1084 : [기초-종합] 빛 섞어 색 만들기(설명) (0) | 2021.07.31 |