鱼C论坛

 找回密码
 立即注册
查看: 1679|回复: 0

[学习笔记] Google foobar challenge

[复制链接]
发表于 2019-8-12 12:27:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Seawolf 于 2019-8-13 11:38 编辑

继续 level 3

69137712_2064691270505813_7487424699094269952_n.png

68751461_2387530648143744_660717990492241920_n.png

因为number的大小 could be 10^50, so we still need big integer.
import java.math.BigInteger;

public class main {

    public static void main(String[] args){

        String x = "4";

        String y = "11";

        BigInteger left = new BigInteger(x);

        BigInteger right = new BigInteger(y);

        BigInteger one = new BigInteger("1");

        int count = 0;

        while(!(left.compareTo(one) ==0 && right.compareTo(one) == 0)){

            if (left.compareTo(right) > 0){

                left = left.subtract(right);

                System.out.println("==============");

                System.out.println(left);

                count++;

            }

            else if (left.compareTo(right) < 0){

                right = right.subtract(left);

                System.out.println("&&&&&&&&&&&&&&&&&");

                System.out.println(right);

                count++;

            }

            else{

                System.out.println("Impossible");
            }


        }

        System.out.println(count);


    }


}

这个code有问题,当一个数特别大,另一个数特别小的时候,会消耗很多的时间,因为每次只从那个较大的数减去较小的数,系统会run out of time and finally it will fail
所以怎么办呢,要相处一个办法来处理两个相差很大的数

Here is the solution:
import java.math.BigInteger;

public class Solution {

    public static String solution(String x, String y){

//        String x = "2";
        //2147483647
//        String y = "1011111111111111111111111111111111111111111111";

        BigInteger left = new BigInteger(x);

        BigInteger right = new BigInteger(y);

        BigInteger one = new BigInteger("1");

        BigInteger zero = new BigInteger("0");

        BigInteger count = new BigInteger("0");

        if(left.compareTo(right) > 0){
            BigInteger quo = left.divide(right);
//            BigInteger result = left.subtract(right);\
            BigInteger quoTimesRight = quo.multiply(right);
            if(quo.compareTo(BigInteger.ONE) > 0 &&  quoTimesRight.compareTo(left) != 0){

//                quoTimesRight = quoTimesRight.subtract(BigInteger.ONE);
                count = count.add(quo);
                left = left.subtract(quoTimesRight);
//                System.out.println(left.toString(10));
//                result = left;
            }


//            return result.toString(10);

        }else if (left.compareTo(right) < 0){
            BigInteger quo = right.divide(left);
//            BigInteger result = right.subtract(left);
            BigInteger quoTimesLeft = quo.multiply(left);
            if(quo.compareTo(BigInteger.ONE) > 0 &&  quoTimesLeft.compareTo(right) != 0){

//                quoTimesLeft = quoTimesLeft.subtract(BigInteger.ONE);
                count = count.add(quo);
                right = right.subtract(quoTimesLeft);
//                result = right;
//                System.out.println(right.toString(10));
            }



//            return result.toString(10);
        }
//            System.out.println("impossible");
//            return "impossible";



        if(left.compareTo(one) < 0 || right.compareTo(one) < 0){

//            System.out.println("impossible");
            return "impossible";
        }

        while(!(left.compareTo(one) == 0 && right.compareTo(one) == 0)){

            if(left.compareTo(right) == 0){

                count = new BigInteger("0");

                break;
            }

            if (left.compareTo(right) > 0){

                left = left.subtract(right);

                count = count.add(one);

//                System.out.println(count.toString(10));

            }

            else if (left.compareTo(right) < 0){

                right = right.subtract(left);

                count = count.add(one);

//                System.out.println(count.toString(10));

            }

            else{
//                System.out.println("impossibimpossle");

                return "impossible";

//                break;
            }


        }
//        System.out.println(Integer.toString(count));

        if(count.compareTo(zero) != 0){

//            System.out.println(count.toString(10));
            return count.toString(10);
        }


        else{

//            System.out.println("impossible");
            return "impossible";
        }



    }

}

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-23 03:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表