[ java ] JavaFestival11 - Question1 - 1937년 Collatz란 사람에 의해 제기된 이 추측은 ? > java

본문 바로가기
사이트 내 전체검색

java

[ java ] JavaFestival11 - Question1 - 1937년 Collatz란 사람에 의해 제기된 이 추측은 …

작성자 웹지기
작성일 21-01-07 00:17 | 조회 6,152 | 댓글 0

본문

JavaFestival11

 - Question1 -  1937년 Collatz란 사람에 의해 제기된 이 추측은

  입력된 수가 짝수라면 2로 나누고, 홀수라면 3을 곱하고 1을 더한 다음

  결과로 나온 수에 같은 작업을 1이 될 때까지 반복할 경우,

  모든 수가 1이 됩니다.

  입력된 수가 6이라면 6→3→10→5→16→8→4→2→1 이 되어 총 8번 만에 1이 됩니다.

  collatzNumber() 메소드를 만들어 입력된 수가 몇 번 만에 1이 되는지 반환해 주세요.

  단, 500번을 반복해도 1이 되지 않는다면 –1을 반환해 주세요.

 


public class Question1 {

    public static void main(String[] args) {

        int number = CollatzNumber(6);

        System.out.println(number);

    }


    private static int CollatzNumber(int num) {

        long n = (long) num;

        for (int i = 0; i < 500; i++) {

            if (n == 1)

                return i;

            n = (n % 2 == 0) ? n / 2 : n * 3 + 1;

        }

        return -1;

    }

}

 

결과

8


0 0

댓글목록 0

등록된 댓글이 없습니다.

java 목록

Total 113
게시물 검색

회원로그인

접속자집계

오늘
13,018
어제
17,832
최대
61,067
전체
17,952,130

그누보드5
Copyright © funyphp.com. All rights reserved.