9.10阿里笔试统计

好像要么就是通过0,要么就是全过...
就过了一题 枯了
#阿里笔试##阿里巴巴#
全部评论
有没有挂0的。。。。
34 回复 分享
发布于 2021-09-10 20:03
第一题贪心思想,先确定谁大谁小。让小的值一直加,直到大于等于较大值,求两者的差值,如果差值为偶数则直接返回加的次数。如果差值是奇数,则继续加,直到差值是偶数为止,返回次数
5 回复 分享
发布于 2021-09-10 20:06
蹲一个第二题,暴力不出来
1 回复 分享
发布于 2021-09-10 19:59
a了第一题,没想到用贪心就能过😂
1 回复 分享
发布于 2021-09-10 20:03
两题都ac了   第一题用队列bfs  第二题注意使用long 存值  查找坐标的象限然后根据对应的象限dfs就行
点赞 回复 分享
发布于 2021-09-10 19:59
有大佬贴下代码吗 哭惹😂😂😂😂😂
点赞 回复 分享
发布于 2021-09-10 20:01
只a了第一题,dfs
点赞 回复 分享
发布于 2021-09-10 20:02
我也想看答案有大佬贴嘛?
点赞 回复 分享
发布于 2021-09-10 20:02
第一题令sum = (1~k)的和,当sum - abs(a-b) >= 0且为偶数时就得到了k,返回计时器即可 第二题看不懂题目,不知所云
点赞 回复 分享
发布于 2021-09-10 20:02
建议加一个路过选项
点赞 回复 分享
发布于 2021-09-10 20:07
第二题题目都看不懂
点赞 回复 分享
发布于 2021-09-10 20:10
第二题我现在有点想到办法,应该是递归地算那个坐标处于子矩阵的哪个区域,这样只用关注加哪个数就行了
点赞 回复 分享
发布于 2021-09-10 20:10
有没有大佬贴一下第二题答案,或者给两个特殊用例也行
点赞 回复 分享
发布于 2021-09-10 20:14
第一题ac 第二题考完三分钟我就做出来了 就差点提交的时间 😅😅
点赞 回复 分享
发布于 2021-09-10 20:14
25min a完第一题提前交卷
点赞 回复 分享
发布于 2021-09-10 20:23
有人能贴一下题目嘛
点赞 回复 分享
发布于 2021-09-10 20:23
public long query(long x,long y,long nums[][]) { if(x<3 && y<3) { return nums[(int) (x-1)][(int)(y-1)]; } else { int i=0,j=0; long temp=x-1;      while(temp>0) {      i++;      temp=temp/2;      }      temp = y-1;      while(temp>0) {      j++;      temp=temp/2;      } if(i==j) { i--; j--; return query((long)(x-Math.pow(2, i)),(long)(y-Math.pow(2, j)),nums)+nums[1][1]; }else if(i>j) { i--; return query((long)(x-Math.pow(2, i)),y,nums)+nums[1][0]; }else { j--; return query(x,(long)(y-Math.pow(2, j)),nums)+nums[0][1]; } } } 因为那个两个WHILE RUNOUT了 = = 本来应该可以过的 忘记log2怎么用math写了
点赞 回复 分享
发布于 2021-09-10 20:25
第二题直接傻了😫
点赞 回复 分享
发布于 2021-09-10 20:26
分数一二题咋分配的啊
点赞 回复 分享
发布于 2021-09-10 20:47
测了8*8内的,我这个方法能行,后边没去核对了。。。 ori = list(map(int, input().split())) ori = [ori[i:i+2] for i in range(0, len(ori), 2)] n = input() for i in range(int(n)):     res = 0     x, y = map(int, input().split())     n = 2     t = 0     while x > n&nbs***bsp;y > n:         n *= 2         t += 1     while n != 1:         if x <= n/2 and y <= n/2:             if n == 2:                 res += ori[0][0]             else:                 res += 0         elif x <= n/2 and y > n/2:             res += ori[0][1]         elif x > n/2 and y <= n/2:             res += ori[1][0]         else:             res += ori[1][1]         n /= 2         if x > n:             x -= n         if y > n:             y -= n     print(res)
点赞 回复 分享
发布于 2021-09-10 21:08

相关推荐

牛客389580366号:读书的意义在于提升自己和他人吧,“阶级意识”是读书过程中的产出,“跨越阶级”是通过读书获得的能力
点赞 评论 收藏
分享
2024-12-02 14:27
Java
点赞 评论 收藏
分享
评论
3
8
分享
牛客网
牛客企业服务