2018春招-今日头条笔试题-第一题(python)

题目描述:2018春招-今日头条笔试题5题(后附大佬答案-c++版)

解题思路:

要想得到输入的数字列中存在相隔为k的数,可以将输入的数字加上k,然后判断其在不在输入的数字列中即可。

#-*- coding:utf-8 -*-
class Fun:

    def __init__(self,string,k):
        self.string=string
        self.k=int(k)
        self._set=set()

    def fun(self):
        l=set() #用于存储,已经比较的数,防止重复比较
        for i in self.string:
            if l not in l:  #只比较未比较的
                if str(int(i)+self.k) in self.string:
                    self._set.add(i + str(int(i)+self.k)) #将符合的数字对以字符串的形式存入集合
                l.add(i)    #已经的比较的放入集合
        return len(self._set)  #返回集合的长度

n_k=raw_input().split(' ')
k=n_k[1]
string=raw_input().split(' ')
print Fun(string,k).fun()

大佬的做法:将输入的数字数列去重,全部加k,生成一个新的list后,比较这里两个list的相同数的个数

#-*- coding:utf-8 -*-
def diff_list(lst, k):
    #将原始字符串转化为int类型加k,生成新的list
    newlst = [str(int(i) + int(k)) for i in lst]
    #将list转为集合(去重),利用&操作得到两个set集合的相同数的集合
    print len(set(lst) & set(newlst))

n_k=raw_input().split(' ')
n=n_k[0]
k=n_k[1]
string=raw_input().split(' ')
diff_list(string,k)

 

转载于:https://www.cnblogs.com/ybf-yyj/p/8651643.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值