Syangguang level
获赞
391
粉丝
3
关注
3
看过 TA
11
四川大学
2018
Java
IP属地:四川
暂未填写个人简介
私信
关注
2018-08-06 10:39
已编辑
四川大学 Java
0 点赞 评论 收藏
分享
2018-04-01 15:31
已编辑
四川大学 Java
0 点赞 评论 收藏
分享
2018-03-26 14:53
已编辑
四川大学 Java
周四晚上8点收到了阿里菜鸟网络的一面技术面电话, 周五下午收到了阿里的二面技术面电话。 我想问一下是不是还有3轮技术面?
sir1209:简历评估一轮,正式一面一轮,正式二面一轮,牛逼的还有交叉面一轮,最后hr一轮。期间如果觉得你水平不错但是岗位不合可能被丢到别的部门从头开始
投递菜鸟集团等公司10个岗位 >
0 点赞 评论 收藏
分享
2018-03-19 20:11
已编辑
四川大学 Java
已知有两个长度相等的正整数数组A、B, 其元素分别记为{a(1),a(2),a(3),a(4) ...... a(n) ......}和{b(1),b(2),b(3),b(4) ...... b(n) ......}, 两个数组中任一元素大小不超过10000,数组长度在1000以内, 现在按照以下规则将A数组中的元素插入到B数组中进行合并: 对于A数组中任一元素可以插入到B数组中任意位置。 对于A数组中任一元素a(i),在合并之后的数组中a(i)对应的下标小于a(i+1)对应的下标。(如果a(i+1)存在的话) 问题: 对合并之后的数...
蓝神(⊙o⊙):class State: def __init__(self, x, y, sum): self.x = x self.y = y self.sum = sum def __str__(self): return 'x=%d y=%d sum=%d'%(self.x, self.y, self.sum) class Solution(object): min = float('inf') def forward(self, a_list, b_list, prev_state): s1_min, s2_min, s3_min = float("inf"), float("inf"), float("inf") a_len = len(a_list) b_len = len(b_list) s1, s2, s3 = None, None, None for state in prev_state: if state == None: continue if [state.x, state.y] == [a_len-1, b_len-1] and state.sum<self.min: self.min = state.sum if (state.x+2 < a_len) and (state.sum + a_list[state.x + 1] * a_list[state.x + 2] < s1_min): s1 = State(state.x + 2, state.y, state.sum + a_list[state.x + 1] * a_list[state.x + 2]) s1_min = s1.sum if (state.x+1 < a_len) and (state.y+1 < b_len) and (state.sum + a_list[state.x + 1] * b_list[state.y + 1] < s2_min): s2 = State(state.x + 1, state.y + 1, state.sum + a_list[state.x + 1] * b_list[state.y + 1]) s2_min = s2.sum if (state.y+2 < b_len) and (state.sum + b_list[state.y + 1] * b_list[state.y + 2] < s3_min): s3 = State(state.x, state.y + 2, state.sum + b_list[state.y + 1] * b_list[state.y + 2]) s3_min = s3.sum return [s1,s2,s3] def min_sum(self, a_list, b_list): prev_state = [State(-1,-1,0),State(-1,-1,0),State(-1,-1,0)] min = float('inf') while prev_state != [None, None, None]: prev_state = self.forward(a_list=a, b_list=b, prev_state=prev_state) return self.min if __name__ == '__main__': a = [1,4,1,1] b = [2,3,4,2] print( Solution().min_sum(a, b) )
投递阿里巴巴等公司10个岗位 >
0 点赞 评论 收藏
分享
关注他的用户也关注了:
牛客网
牛客企业服务