zhuifeng66666 2021-12-27 16:17 采纳率: 50%
浏览 107
已结题

用Python,用奇偶性判断幸运数字

问题遇到的现象和发生背景

如果它的奇数位置的数字的和等于偶数位置的数字的和,那么我们称票为幸运的。
写下一个函数,它以一个票号作为参数,并返回最近的幸运票号(如果有两个的话)。
最接近的票号意味着它与给定的票号之间的绝对差异被最小化。
一个给定的票务号码应该是一个可接受的自然2𝑘位数(它有偶数位数),没有前导零。
笔记将程序保存到文件ticket.py中,并为解决方案函数提供名称get_nearest_lucky_ticket。

问题相关代码,请勿粘贴截图
Example
assert get_nearest_lucky_ticket ( 111111 ) == 111111
assert get_nearest_lucky_ticket ( 123321 ) == 123321
assert get_nearest_lucky_ticket ( 123320 ) == 123321
assert get_nearest_lucky_ticket ( 333999 ) == 334004

我想要达到的结果

代码最后使用以上assert测试代码,代码写一下注释。

  • 写回答

2条回答 默认 最新

  • 天际的海浪 2021-12-27 18:25
    关注
    
    def get_nearest_lucky_ticket(n):
        i = 0
        while i<=n:
            li = list(map(int,str(n+i)))
            a = sum(li[0::2])
            b = sum(li[1::2])
            if a==b:
                return n+i
            li = list(map(int,str(n-i)))
            a = sum(li[0::2])
            b = sum(li[1::2])
            if a==b:
                return n-i
            i += 1
    assert get_nearest_lucky_ticket ( 111111 ) == 111111
    assert get_nearest_lucky_ticket ( 123321 ) == 123321
    assert get_nearest_lucky_ticket ( 123320 ) == 123321
    assert get_nearest_lucky_ticket ( 333999 ) == 334004
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月5日
  • 已采纳回答 12月28日
  • 修改了问题 12月27日
  • 创建了问题 12月27日

悬赏问题

  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题
  • ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体