实验五 字符类型及其操作-第4关:信用卡号校验

本关任务要求编写一个Python程序,使用Luhn算法检查信用卡号的合法性。算法包括逆向奇数位相加,偶数位乘以2后求和(超过9则减9),然后将两部分和相加,结果应能被10整除。示例中,5432123456788881通过校验,而955876543未通过。
摘要由CSDN通过智能技术生成

任务描述

本关任务:编写一个能判断信用卡号是否合法的小程序。

信用卡号必须通过lun算法进行校验,其过程: 1、从卡号最后一位数字开始,逆向将奇数位(1、3、5等等)相加。 2、从卡号倒数第二位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去9),再求和。 3、将奇数位总和加上偶数位总和,结果应该可以被10整除。 例如,卡号是:5432123456788881 逆向奇数位为 4 2 2 4 6 8 8 1 和 = 35 逆向偶数位乘以2(有些要减去9)的结果:1 6 2 6 1 5 7 7,求和 = 35。 最后 35 + 35 = 70 可以被10整除,认定校验通过。 注意:信用卡的卡号长度是根据输入来确定的。

提示: <字符串>[结尾字符:开始字符:<负整数>] 可以逆序间隔地取字符 例如 x="hello world"x[-1::-2]表示从结尾字符每隔2个字符取子串,即"drwolh"

编程要求

根据提示,在右侧编辑器补充代码,判断信用卡号是否合法。

测试说明

平台会对你编写的代码进行测试:

测试输入:5432123456788881; 预期输出: 合法卡号

测试输入:955876543; 预期输出: 非法卡号

def is_valid_credit_car
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值