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

본문 바로가기

사이트 내 전체검색

java

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

작성일 21-01-07 00:17

페이지 정보

작성자 웹지기 조회 2,185회 댓글 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

댓글목록

등록된 댓글이 없습니다.

전체 113건 1 페이지

이미지 목록

게시물 검색
Copyright © 즐거운 코딩 생활 ( funyphp ). All rights reserved.
PC 버전으로 보기