阿里7.24笔试

第一道吃烧饼一分钟解决,第二道59分钟不知道怎么搞……
第一题Python代码
def f(nums):
    for i in range(1, len(nums)):
        nums[i] = min(nums[i - 1], nums[i])
    return sum(nums)

第二题Python代码
def f(nums1, nums2):
    if not nums1&nbs***bsp;not nums1[0]:
        return 0
    N, L = len(nums1), len(nums1[0])
    res = 0
    for col in range(L):
        col1 = (x[col] for x in nums1)
        col2 = (x[col] for x in nums2)
        sum1, sum2 = sum(col1), sum(col2)
        if sum1 != sum2 and sum1 + sum2 != N:
            return -1
        elif sum1 == sum2:
            continue
        else:
            res += 1
            for row in range(N):
                nums1[row][col] = 1 - nums1[row][col]
    nums1.sort()
    nums2.sort()
    if nums1 == nums2:
        return res
    else:
        return -1



#笔试题目##阿里巴巴#
全部评论
我的思路是这样的, 先把列中 ‘1’的个数的不匹配的每列翻转过来,翻转解决不了的直接No Result,总翻转次数记为 ans,用一个hashmap统计翻转之后的原始灯泡排列与预期的灯泡排列中每行的字符串出现频率,相等的话可以转化输出 ans,你看可以吗
2 回复 分享
发布于 2020-07-24 21:12
求个问题描述
点赞 回复 分享
发布于 2020-07-24 22:53
第二题过了40%,剩下的超时,看了半个小时也不知道怎么优化。。。
点赞 回复 分享
发布于 2020-07-24 22:09
牛啤
点赞 回复 分享
发布于 2020-07-24 21:26
请问第一题是怎么理解呢
点赞 回复 分享
发布于 2020-07-24 20:52
看到大家都只a了一道,我就放心了😂
点赞 回复 分享
发布于 2020-07-24 20:47
我第二题先判断相等,再判断不等但求和为N,过了20🤣
点赞 回复 分享
发布于 2020-07-24 20:25
我大概知道第二题代码哪里有问题了
点赞 回复 分享
发布于 2020-07-24 20:24

相关推荐

全A了,但是美团还有HC吗
投递美团等公司10个岗位
点赞 评论 收藏
分享
xiaolihuam...:当然还有一种情况是你多次一面挂,并且挂的原因都比较类似,例如每次都是算法题写不出来。面试官给你的评价大概率是算法能力有待加强,算法能力有待提高,基础知识掌握的不错,项目过关,但是coding要加强。短期内高强度面试并且每次都是因为同样的原因挂(这个你自己肯定很清楚),会形成刻板印象,因为你偶尔一次算法写不出来,面试官自己也能理解,因为他清楚的知道自己出去面试也不一定每一次面试算法都能写出来。但是连续几次他发现你的面屏里面都是算法有问题,他就认为这不是运气问题,而是能力问题,这种就是很客观的评价形成了刻白印象,所以你要保证自己。至少不能连续几次面试犯同样的错。算法这个东西比较难保证,但是有些东西是可以的,例如某一轮你挂的时候是因为数据库的索引,这个知识点答的不好,那你就要把数据库整体系统性的复习,下一轮面试你可以,项目打的不好,可以消息队列答的不好,但是绝对不可以数据库再答的不好了。当然事实上对于任何面试都应该这样查漏补缺,只是对于字节来说这个格外重要,有些面试官真的会问之前面试官问过的问题
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
4
6
分享

创作者周榜

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