鱼C论坛

 找回密码
 立即注册
查看: 1656|回复: 5

[技术交流] Python:每日一题 223

 关闭 [复制链接]
发表于 2019-7-5 18:59:42 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 新手·ing 于 2019-7-7 08:52 编辑
今天的题比较简单,大家积极参与呀

对于非负整数 X 而言,X 的数组形式是每位数字按从左到右的顺序形成的数组。例如,如果 X = 1231,那么其数组形式为 [1,2,3,1]。

给定非负整数 X 的数组形式 A,返回整数 X+K 的数组形式。



  1. 示例 1:

  2. 输入:A = [1,2,0,0], K = 34
  3. 输出:[1,2,3,4]
  4. 解释:1200 + 34 = 1234
  5. 解释 2:

  6. 输入:A = [2,7,4], K = 181
  7. 输出:[4,5,5]
  8. 解释:274 + 181 = 455
  9. 示例 3:

  10. 输入:A = [2,1,5], K = 806
  11. 输出:[1,0,2,1]
  12. 解释:215 + 806 = 1021
  13. 示例 4:

  14. 输入:A = [9,9,9,9,9,9,9,9,9,9], K = 1
  15. 输出:[1,0,0,0,0,0,0,0,0,0,0]
  16. 解释:9999999999 + 1 = 10000000000
复制代码


萌新解法:
  1. def addToArrayForm(A, K):
  2.         return [int(i) for i in str(int(''.join([str(n) for n in A]))+K)]
复制代码

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-7-5 21:44:42 From FishC Mobile | 显示全部楼层
def delist(lista):
    result = 0
    for i in lista:
        result=result*10+i
    return result
def enlist(inta):
    lista=[]
    s=str(inta)
    for i in s:
        lista.append(int(i))
    return lista
if __name__ == '__main__':
    lista=[1,2,9,6,5]
    inta=234
    temp=delist(lista)   
    temp += inta
    result = enlist(temp)
    print('结果是:',result)

评分

参与人数 1鱼币 +10 收起 理由
新手·ing + 10

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-6 10:45:59 | 显示全部楼层
class F:
    def __init__(self,x,y):
        self.x = x
        self.y = y
    #数字相加并转换为字符
    def add1(self):
        sum1 = self.x + self.y
        str1 =str(sum1)
        return str1
    #字符输出列表
    def list1(self):
        list2 = []
        str2 = self.add1()
        for i in str2:
            list2.append(i)
        return list2

if __name__ == '__main__':
    s = F(1235,58)
    print('输出的数组为:',s.list1())


评分

参与人数 1鱼币 +10 收起 理由
新手·ing + 10

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-6 15:40:34 | 显示全部楼层
我看到这道题后,目前能够想到的也是楼主的方法,即转字符串把数字放在一起变整形相加的方法。不知道有没有大佬有更简单的方法,楼上的方法其实把问题弄得更复杂,你这道题还可以往难点玩,就是A列表里的数可以自由组合(甚至可以选取一两个数来做加法)比方说A=[1,2,5]可以是125,152,215,251,512,521这种:
  1. from itertools import permutations
  2. def addToArrayForm(A, K):
  3.     B=list(permutations(A,3))
  4.     for C in B:yield [int(i) for i in str(int(''.join([str(n) for n in C]))+K)]
  5. print(*addToArrayForm([2,1,5],806))
复制代码

评分

参与人数 1鱼币 +10 收起 理由
新手·ing + 10

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-6 19:41:42 | 显示全部楼层
试个不用str的方法。
  1. def fun223(a, k):
  2.     from functools import reduce
  3.     i = reduce(lambda x, y: 10 * x + y, a) + k
  4.     result = []
  5.     while i:
  6.         result.insert(0, i % 10)
  7.         i //= 10
  8.     return result
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-6 23:13:34 | 显示全部楼层
  1. def fun230(A,K):
  2.     b=0
  3.     c=[]
  4.     for i in range(0,len(A)):
  5.         b+=A[i]*pow(10,(len(A)-i-1))
  6.     b+=K
  7.     b=str(b)
  8.     for i in range(len(b)):
  9.         c.append(b[i])
  10.     print(c)

  11. if __name__ == '__main__':
  12.     fun230(A,K)
复制代码

评分

参与人数 1鱼币 +10 收起 理由
新手·ing + 10

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-27 07:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表