温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具
所有文章 友链 关于我

温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具

银行卡校验规则(Luhn算法)

2017-08-05

原文:http://www.icloudyin.com/?p=61

  • 检验数字算法(Luhn Check Digit Algorithm),也叫做模数10公式,是一种简单的算法,用于验证银行卡、信用卡号码的有效性的算法。对所有大型信用卡公司发行的信用卡都起作用,这些公司包括美国Express、护照、万事达卡、Discover和用餐者俱乐部等。这种算法最初是在20世纪60年代由一组数学家制定,现在Luhn检验数字算法属于大众,任何人都可以使用它。
  • 将卡号上的每个数字乘上其权重(weight),如果卡号上的数字个数是偶数,那么第一个数字的权重就是2,若是奇数,那么权重就给1,剩下来的数字,根据第一个数字依序给定。例如某信用卡卡号的数字个数为偶数,那么从第一个数字开始的权重依序为 2、1、2、1、2、1 …。
  • 如果数字乘上自己的权重后比9还大,那么就从这加权数字里扣除9。
  • 接下来将所有处理过的加权数字全部加总起来,并且除以10,取其余数。

java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int sum = 0;
boolean even = true;
for ( int index = digits.size() - 1; index >= 0; index-- ) {
int digit = digits.get( index );

if ( even ) {
digit <<= 1;
}
if ( digit > 9 ) {
digit -= 9;
}
sum += digit;
even = !even;
}
return ( 10 - ( sum % 10 ) ) % 10;

python

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def check_bank_card(card_num):
"""检查银行卡的合法性"""
total = 0
even = True
if isinstance(card_num, int):
card_num = str(card_num)
check_num = card_num[-1]
for item in card_num[-2::-1]:
item = int(item)
if even:
item <<= 1
if item > 9:
item -= 9
total += item
even = not even
return int(check_num) is (10 - (total % 10)) % 10
最近更新
Alfred Workflow 命令行帮助工具
最近热读
Go 判断数组中是否包含某个 item
Vim 高级功能 vimgrep 全局搜索文件
办理北京工作居住证的一些细节
Go 语法错误:Non-declaration statement outside function body
Mac 电脑查看字体文件位置
扫码关注公众号,或搜索公众号“温欣爸比” 及时获取我的最新文章
赏

谢谢你请我喝咖啡

支付宝
微信
  • 算法
Mysql 基础命令
身份证号码校验规则
  1. 1. java
  2. 2. python
© 2017 - 2022 温欣爸比 京ICP备15062634号 总访问量3644次 访客数3595人次 本文总阅读量4次
Hexo Theme Yilia by Litten
  • 所有文章
  • 友链
  • 关于我

tag:

  • python
  • flask
  • javascript
  • docker
  • 工具
  • openresty
  • 微信
  • java
  • hexo
  • 杂谈
  • vim
  • git
  • mysql
  • http
  • linux
  • mac
  • tmux
  • ssh
  • 算法
  • 开发
  • node
  • 杂文
  • jinja2
  • maven
  • spring
  • 北京
  • 生活
  • springboot
  • react
  • shell
  • graphql
  • iterm
  • expect
  • nginx
  • sqlalchemy
  • html
  • electron
  • vagrant
  • elastic
  • 宝贝
  • ansible
  • css
  • jquery
  • go
  • markdown
  • awk
  • redis
  • leetcode
  • zsh
  • 漫威
  • ssr
  • android
  • ffmpeg
  • chrome
  • vmware
  • youtube
  • windows
  • jupyter
  • excel
  • jq
  • Mac
  • Homebrew
  • mongo
  • py2
  • HomeBrew
  • movie
  • nodejs

    缺失模块。
    1、请确保node版本大于6.2
    2、在博客根目录(注意不是yilia根目录)执行以下命令:
    npm i hexo-generator-json-content --save

    3、在根目录_config.yml里添加配置:

      jsonContent:
        meta: false
        pages: false
        posts:
          title: true
          date: true
          path: true
          text: false
          raw: false
          content: false
          slug: false
          updated: false
          comments: false
          link: false
          permalink: false
          excerpt: false
          categories: false
          tags: true
    

  • Guru99
每天看书
每天背单词
每天一篇
写写代码
听听周杰伦
爱爱老婆