일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 성분
- C
- 프로그래밍언어
- 지혜를가진흑곰
- algorithmtraining
- 자바스크립트
- 백준알고리즘
- 독후감
- C++
- 다독
- algorithmTest
- 돈
- 경제
- 알고리즘공부
- 책알남
- 화장품
- 주식
- 자바
- 프로그래머스 알고리즘 공부
- 채권
- 알고리즘 공부
- JavaScript
- 책을알려주는남자
- algorithmStudy
- 재테크
- Java
- 투자
- 알고리즘트레이닝
- 서평
- 독서
Archives
- Today
- Total
탁월함은 어떻게 나오는가?
[알고리즘 트레이닝 3] 백준알고리즘 자바 벌집 본문
반응형
DAY ONE 을 잊지말자!!
위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌을 때, 벌집의 중앙 1에서 N번 방까지 최소 개수의 방을 지나서 갈 때 몇 개의 방을 지나가는지(시작과 끝을 포함하여)를 계산하는 프로그램을 작성하시오. 예를 들면, 13까지는 3개, 58까지는 5개를 지난다.
입력 :
첫째 줄에 N(1 ≤ N ≤ 1,000,000,000)이 주어진다.
출력 :
입력으로 주어진 방까지 최소 개수의 방을 지나서 갈 때 몇 개의 방을 지나는지 출력한다.
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
|
import java.util.Scanner;
public class Algorithms0608 {
public static void main(String[] args) {
// 1 : 1
// 2 ~ 7 : 2 1~6
// 8 ~ 19 : 3 1~12
// 20 ~ 37 : 4 1~18
// 38 ~ 61 : 5 1~24
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int start = 1;
int cnt = 1;
while (true) {
if (n <= start) break;
start += 6 * (cnt-1); cnt++;
System.out.println("start ::: " + start);
}
System.out.println("n ::: " + n);
System.out.println("cnt :::: " + cnt);
cnt = n > 1 ? cnt - 1 : 1;
System.out.println(cnt);
}
}
|
cs |
반응형
'[Snow-ball]프로그래밍(컴퓨터) > Algorithm Training' 카테고리의 다른 글
[알고리즘 트레이닝] 백준 알고리즘 11720번 : 숫자의 합 [JAVA] (0) | 2021.06.15 |
---|---|
[알고리즘 트레이닝] 백준 알고리즘 11654번 : 아스키 코드 [JAVA] (0) | 2021.06.13 |
[알고리즘 트레이닝4] 백준 알고리즘 1193번 : 분수찾기 [JAVA] (0) | 2021.06.12 |
[알고리즘 트레이닝 2] 백준알고리즘 손익분기점 (0) | 2021.06.07 |
[알고리즘 트레이닝 1]두 정수 A와 B를 입력받은 다음, A + B를 출력하는 프로그램을 작성하시오 (0) | 2021.06.05 |
Comments