腾讯测试开发一面挂 这道题有没有人能进来讨论一下

 有[ a、b、c ]三个正整数。由于条件有限,数值范围在 [ 0 < n < 100]。
实现两个方法,解决以下逻辑:
a + b = c;
c - a = b; 或 c - b = a; 
如果a和b是99的话,c=a+b也只能按最大值99来存储,但是又要求b=c-a就是99-99能得出99的这个结果。
我一开始用了一个自定义类的方法
class number{
	int val;
	number(int val){
		this.val=val;
	}
	public int get(number a) {
		if(val<0)
			return 0;
		if(val>99)
			return 99;
		return a.val;
	}
}

public class test1 {
public static void main(String[] args) {
	number a= new number(95);
	number b= new number(6);
	number c=add(a, b);
	System.out.println(c);
	number d=sub(c,a);
	System.out.println(d);
}
public static number add(number a,number b) {
	return new number(a.val+b.val);
}
public static number sub(number a,number b) {
	return new number(a.val-b.val);
}
}


    面试官挺不满意的,说不能用辅助空间。 然后说让我再想想,做好了再发给他,就结束了面试。问他说是用溢出和回溯的算法。去腾讯官网查简历状态就已经灰掉了,但我还是想知道这道题如果不用辅助空间的话该怎么做啊
#腾讯##测试工程师##笔试题目#
全部评论
感觉这道题,你的那个sub函数是不是不能满足要求呀?如果a=99,b=99,你最终输出的d是0不是99,不符合题意~我感觉应该是给c加上一个flag,如果超出99的话,就把多余的值赋给flag,然后就不影响后续的相减了
点赞 回复 分享
发布于 2019-08-30 16:58
我也收到的面试邀请,求问面经呀?大致会问些什么呀
点赞 回复 分享
发布于 2019-08-30 16:54
还有编程题做?
点赞 回复 分享
发布于 2019-08-30 11:41
是TEG吗?我下午也收到了测开的面试
点赞 回复 分享
发布于 2019-08-29 16:13
现场面还是远程?
点赞 回复 分享
发布于 2019-08-29 15:38
你好快啊,我还没有开始呢
点赞 回复 分享
发布于 2019-08-29 15:33

相关推荐

暴杀流调参工作者:春招又试了一些岗位,现在投递很有意思,不仅要精心准备简历,投递官网还得把自己写的东西一条一条复制上去,阿里更是各个bu都有自己的官网,重复操作无数次,投完简历卡完学历了,又该写性格测评、能力测评,写完了又要写专业笔试,最近还有些公司搞了AI辅助编程笔试,有些还有AI面试,对着机器人话也听不明白录屏硬说,终于到了人工面试又要一二三四面,小组成员面主管面部门主管面hr面,次次都没出错机会,稍有不慎就是挂。 卡学历卡项目卡论文卡实习什么都卡,没有不卡的😂
点赞 评论 收藏
分享
评论
点赞
9
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务