奇安信笔试(含代码)

笔试挺简单的,但不知道为什么第一道题就80%,第二道题倒是直接ac了,有大佬知道为啥第一个就80%吗,求指导
第一题,先买性价比高的口罩
while 1:
    a = int(input())
    list1 = [[1, 5], [2, 3], [2, 3], [2, 2], [5, 4], [3, 1]]
    count = 0
    sum = 0
    jilu = []
    while a > 0 and list1:
        count = 0
        for i in range(len(list1)):
            if a >= list1[i][0] and i not in jilu:
                a -= list1[i][0]
                sum += list1[i][1]
                count += 1
                jilu.append(i)
        if count == 0:
            break
    print(sum)
第二题,很简单,循环队列
class Lb:
    class Node:
        def __init__(self,item):
            self.value=item
            self.next=None
    def __init__(self):
        self.head=self.Node(None)
        self.tail=self.Node(None)
        self.head.next=self.tail
        self.tail.next=self.head
        self.total=[]
    def add(self,item):
        node1=self.Node(item)
        node1.next=self.head.next
        self.head.next=node1
    def sump(self):
        count=0
        sum2=0
        while self.head.value==None:
            self.head=self.head.next
        sum2 += self.head.value
        self.head=self.head.next
        while count<3:
            if self.head.value!=None and self.head.value not in self.total and count<=1:
                self.total.append(self.head.value)
                sum2+=self.head.value
                count+=1
                self.head=self.head.next
            elif  self.head.value!=None and self.head.value not in self.total and count==2:
                self.total.append(self.head.value)
                sum2 += self.head.value
                count += 1
            elif self.head.value==None:
                self.head = self.head.next
            elif self.head.value!=None and self.head.value  in self.total:
                sum2 += self.head.value
                break
        return sum2
a=list(map(int,input().split(',')))
lb1=Lb()
for i in a[::-1]:
    lb1.add(i)
sum1=lb1.sump()
sum2=lb1.sump()
sum3=lb1.sump()
if sum1==sum2 and sum2==sum3:
    print("yes")
else:
    print("no")


#奇安信笔试##奇安信##笔试题目#
全部评论
10元的时候最多可以买15个,即1元(5个),2元(3个)2元(3个)和5元(4个)的口罩。
4 回复
分享
发布于 2020-03-28 21:17
第二题有这么复杂吗,不就是按照公式算一下三个值是否一样吗
2 回复
分享
发布于 2020-03-29 13:56
联易融
校招火热招聘中
官网直投
说错了,第二题用的循环链表
点赞 回复
分享
发布于 2020-03-28 21:09
第一题 做法有问题,你这种做法的话,5块钱的情况应该是买4个口罩 而不是2+1=3个
点赞 回复
分享
发布于 2020-03-28 21:12
第二题有人直接sout("yes")就AC了
点赞 回复
分享
发布于 2020-03-28 21:21
怎么把代码发出来呀,我发显示字数超出限制,
点赞 回复
分享
发布于 2020-03-28 21:31
第二题直接按照题目图片的123...9一个一个边加起来,判断就可以了。。我开始以为我把题目想简单了没想到真的这么简单
点赞 回复
分享
发布于 2020-03-28 22:03
我第一题也是80%hhhh
点赞 回复
分享
发布于 2020-03-28 22:04
哈哈哈哈我们80的都用了性价比这个后知后觉
点赞 回复
分享
发布于 2020-03-28 22:55
第一题动态规划的01背包问题,换了名,剩下的全没变,第二题就是数学判断
点赞 回复
分享
发布于 2020-03-28 23:08
头一回做出编程题,前两天阿里思路偏了,两个零蛋😫
点赞 回复
分享
发布于 2020-03-28 23:10

相关推荐

3 10 评论
分享
牛客网
牛客企业服务