A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© xh_javaee 中级黑马   /  2016-9-11 22:37  /  262 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

import java.util.LinkedList;
import java.util.Scanner;


public class Test4 {

        public static void main(String[] args) {
                System.out.println("求第几个丑数");
                int n = new Scanner(System.in).nextInt();
               
                long ugly = chouShu(n);
                System.out.println(ugly);
        }

        private static long chouShu(int n) {
                LinkedList<Long> list3 = new LinkedList<>();
                LinkedList<Long> list5 = new LinkedList<>();
                LinkedList<Long> list7 = new LinkedList<>();
               
                list3.add(3L);//
                list5.add(5L);
                list7.add(7L);
               
                long r = 0;
                for(int i=1; i<=n; i++) {
                        long a = list3.getFirst();
                        long b = list5.getFirst();
                        long c = list7.getFirst();
                        r = Math.min(a, Math.min(b, c));
                        if(r == a) list3.removeFirst();
                        if(r == b) list5.removeFirst();
                        if(r == c) list7.removeFirst();
                       
                        list3.add(r*3);
                        list5.add(r*5);
                        list7.add(r*7);
                }
               
                return r;
        }
}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马