AI模拟面试java软件_牛客的AI模拟面试(1)

本文介绍了在AI模拟面试中遇到的Java相关问题,包括String的不可变性,final、finally和finalize的区别,平衡二叉树的判断,类与对象的区别,重载和重写的辨析,以及计算整数二进制表示中1的个数的方法。通过这些内容,可以帮助Java开发者更好地准备面试。
摘要由CSDN通过智能技术生成

1、请解释一下String为什么不可变?

String是final修饰,不可变,同时string底层是字符数组也是final修饰,这样做首先是安全,比如hashset中用string做为键,不会出现string变化,导致违反唯一键。另外节约内存。

2、请说明一下final, finally, finalize的区别。

final用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。

finally是异常处理语句结构的一部分,表示总是执行。

finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法。

3、输入一棵二叉树,判断该二叉树是否是平衡二叉树。

public static boolean IsBalanced_Solution(TreeNode root) {

if(root == null){

return true;

}

int left = iterTree(root.left);

int right = iterTree(root.right);

if(Math.abs(left-right) > 1){

return false;

}

return true;

}

private static int iterTree(TreeNode root) {

if(root == null){

return 0;

}

int left = iterTree(root.left);

int right = iterTree(root.right);

return left > right ? (left+1) : (right+1);

}

1、请说明类和对象的区别

类是对象的抽象,对象是类的实例

2、请说明Overload和Override的区别,Overloaded的方法是否可以改变返回值的类型?

重载发生在一个类中,在编译期绑定,方法名相同而参数列表不同;

重写发生在父子类中,在运行期绑定,方法名相同,参数列表相同,方法体不同,主要遵循一大二小三相等:

访问修饰符要大于或等于父类,

返回类型如果是基本数据类型的话,要与父类相同,如果是引用类型的话,小于过等于父类;

抛出异常要比父类小或等于。

3、输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。

https://blog.csdn.net/qq_33575542/article/details/81054108

&是二进制“与”运算,参加运算的两个数的二进制按位进行运算,运算的规律是:

0 & 0=0

0 & 1=0

1 & 0=0

1 & 1=1

对于参加运算的数要换算为二进制进行运算,例如3 & 2的结果是2,过程如下:

3 & 2

=0111 & 0010

=0010

=2

思路:

把一个整数和它减去1的结果做位与运算,相当于把它最右边的1变成0。

所以,这种方法,只要这个整数有几个1,就做几次这样的操作。

private static int NumberOf1(int n){

int count = 0;

while(n!=0){

count++;

n = n&(n-1);

}

return count;

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值