全部评论
有没有挂0的。。。。
第一题贪心思想,先确定谁大谁小。让小的值一直加,直到大于等于较大值,求两者的差值,如果差值为偶数则直接返回加的次数。如果差值是奇数,则继续加,直到差值是偶数为止,返回次数
蹲一个第二题,暴力不出来
a了第一题,没想到用贪心就能过😂
两题都ac了 第一题用队列bfs 第二题注意使用long 存值 查找坐标的象限然后根据对应的象限dfs就行
有大佬贴下代码吗 哭惹😂😂😂😂😂
只a了第一题,dfs
我也想看答案有大佬贴嘛?
第一题令sum = (1~k)的和,当sum - abs(a-b) >= 0且为偶数时就得到了k,返回计时器即可 第二题看不懂题目,不知所云
建议加一个路过选项
第二题题目都看不懂
第二题我现在有点想到办法,应该是递归地算那个坐标处于子矩阵的哪个区域,这样只用关注加哪个数就行了
有没有大佬贴一下第二题答案,或者给两个特殊用例也行
第一题ac 第二题考完三分钟我就做出来了 就差点提交的时间 😅😅
25min a完第一题提前交卷
有人能贴一下题目嘛
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写了
第二题直接傻了😫
分数一二题咋分配的啊
测了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)
相关推荐
2024-12-02 01:32
中国地质大学(武汉) 电路设计工程师 点赞 评论 收藏
分享