栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

阿里巴巴校招笔试题10.8

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

阿里巴巴校招笔试题10.8

  • 阿里巴巴10.8号笔试题
    • 题目描述
    • 算法分析
    • 关键步骤
    • 最后附上实现代码
    • 后记

)

阿里巴巴10.8号笔试题 题目描述 题目描述:给定一组或多组三十二位长度的补码数字,返回每组数字加和后的十进制的数字。 算法分析 算法分析:
首先,数字的补码,有正负之分,正整数的补码就是正码。而唯一需要注意的是负整数的补码是它的反码加一。所以根据补码就要减去一,再将求出反码。
关键步骤


第一,判断正负。取字符串第一位数字判断。


第二,字符串是32位长度,存在大量的冗余,所需要的只是后几位的数字。而确定从何处切下的关键在于:正数从左向右,找到第一个1;负数从右向左,找到第一个0。


第三,处理负数字符串,这里用到了位运算<<1。将原字符串切下后的有效部分,先转为十进制整数并减去一,再将减一后的整数进行位运算,记住最后要取负数。

最后附上实现代码
//import java.util.Scanner;
public class Main3 {
    public static void main(String[] args) {
        //        Scanner sc = new Scanner(System.in);
        //        int t = sc.nextInt();//有几组数组
        //        String[] strs = new String[2*t];
        //        for(int i=0;i<2*t;i++){
        //            strs[i] = sc.next();
        //        }
                String[] strs = new String[]{
                        "11111111111111111111111111010110",// -42
                        "00000000000000000000000000010100" // 20
                };
                int[] counts = Count(strs);
                for(int i = 0;i 
后记 

这道题目的算法关键在于知晓位运算,就可以省下很大的气力。大厂尤其重视算法基础,特别是应届毕业生。最后在2021年秋招基本结束之际,预祝大家拿到心仪的offer。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/305335.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号