【Java校招面试】实战算法(二)——2的N次方(迅雷)


前言

“实战算法”是本专栏的第三个部分,本篇博文是第二篇博文,主要讲解迅雷笔试题——2的N次方——的解法,如有需要,可:

  1. 点击这里,返回本专栏的索引文章
  2. 点击这里,返回上一篇《【Java校招面试】实战算法(一)——背包问题总结》
  3. 点击这里,前往下一篇《【Java校招面试】实战算法(三)——宝箱怪(百度)》

一、题目描述

对于一个整数N(512 <= N <= 1024),计算2的N次方并在屏幕显示十进制结果。

  1. 输入描述:
    输入一个整数N(512 <= N <= 1024)

  2. 输出描述:
    2的N次方的十进制结果

  3. 样例输入
    512

  4. 样例输出
    13407807929942597099574024998205846127479365820592393377723561443721764030073546976801874298166903427690031858186486050853753882811946569946433649006084096


二、代码实现

	import java.util.*;
	public class Main{
	    public static void main(String[] args){
	        Scanner in = new Scanner(System.in);
	        int input = in.nextInt();
	        String result = "1";
	        for (int i = 0; i < input; i++)
	            result = multiplyByTwo(result);
	        System.out.println(result);
	    }
	     
	    // 对当前数值(字符串)进行x 2的操作
	    public static String multiplyByTwo(String num){
	        char[] chars = num.toCharArray();
	        // 进位
	        int carry = 0;
	        for (int i = num.length() - 1; i >= 0; i--){
	            int tmp = (chars[i] - 48) * 2 + carry;
	            chars[i] = (char)(tmp % 10 + 48);
	            carry = tmp / 10;
	        }
	        if (carry != 0){
	            return String.valueOf(carry) + new String(chars);
	        } else {
	            return new String(chars);
	        }
	    }
	}

三、代码说明

由于N的范围在[512, 1024]之间,指数的结果会非常大,整型和长整型都会溢出,职能使用字符串来表示。

代码分为两个方法,主方法中循环N次,multiplyByTwo将当前的字符串表示的数值进行x 2操作。


四、偷懒的方法

如果不怕出题人复查代码,可以使用BigInteger类,其中有相关的方法,一行即可解决:

	return BigInteger.valueOf(2).pow(N).toString();

后记

本题主要考察控制台输入输出、字符串操作和作答者的细心(考虑进位等情况)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IMplementist

你的鼓励,是我继续写文章的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值