鱼C论坛

 找回密码
 立即注册
查看: 1762|回复: 4

算法求解,内有练习(求,大佬,萌新同看)

[复制链接]
发表于 2021-4-20 23:41:47 | 显示全部楼层 |阅读模式

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

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

x
这道题我是这样解答的:
def  dl():
    ans=0
    global x
    x = 1
    while ans  <  2020:
        ans=0
        x+=1
        for i in range(1,x):
            ans+=str(i).count("1")

def main():
    dl()
    print(x)
   
   
if __name__ == "__main__":
    main()

想让大佬帮忙修改下()
遇到以下问题:
1.有时两个不同数返回相同的值(3,4返回12)(2020,2021返回2182)
2.最后得出的答案是(输出的值)2182,我不清楚到底是2182还是2181
3.希望大佬指正(多谢,)

有助于编程逻辑训练

有助于编程逻辑训练
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-4-21 09:45:26 | 显示全部楼层
cards = {}
for i in range(10):
    cards[str(i)] = 2021
##print(cards)

num = flg = 1
while flg:
    for i in str(num):
        if cards[i] == 0:
            print(num - 1)
            flg = 0
            break
        else:
            cards[i] -= 1
    num += 1
print("剩余卡片:",cards)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-21 09:48:19 | 显示全部楼层
看不懂你写的
这是我的思路:

cards = {'0':2021, '1':2021, '2':2021, '3':2021, '4':2021,
                 '5':2021, '6':2021, '7':2021, '8':2021, '9':2021,} #拥有的各种卡片数
x = 1 #从x = 1 开始拼
while True:
        for i in str(x):
                cards[i] -= 1 #每拼一个数消耗其中对应的卡片
        if -1 in cards.values():  #如果有一个卡片数变成-1说明卡片数不够拼这个数,说明只能拼到x-1这个数
                x -= 1
                break  
        x += 1 #继续试着往下拼
print(x)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-21 09:49:01 | 显示全部楼层
本帖最后由 qq1151985918 于 2021-4-21 09:52 编辑

不知道为什么审核了...

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-9 01:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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