信用卡号校验

本文介绍了一种用于信用卡号码校验的Luhn算法,详细解释了算法的工作原理,并提供了一个C语言实现的示例代码,帮助读者理解如何通过Luhn算法验证信用卡号码的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


当你输入信用卡号码的时候,有没有担心输错了而造成损失呢?其实可以不必这么担心,因为并不是一个随便的信用卡号码都是合法的,它必须通过Luhn算法来验证通过。


该校验的过程:

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整除,认定校验通过。


请编写一个程序,从标准输入获得卡号,然后判断是否校验通过。

通过显示:“成功”,否则显示“失败”。


比如,

输入:356827027232780

程序输出:成功


本题关键:读懂题意,从卡位最后一位数字开始,逆向,也就是,最后一位为第1位,倒数第二位为第2位

#include<stdio.h>
#include<string.h>
int main(){
	int n,i,sum,m;
	char s[100],s1[100];
	scanf("%s",&s1);
	n=strlen(s1);
	sum=0;
	m=n;
	s[m]='\0';
	for(i=0;i<n;i++){    
		s[--m]=s1[i];
	}
	
	printf("%s\n",s);
	for(i=0;i<n;i++){
		if(i%2==0){
			sum+=(s[i]-48);
			printf("%d寄:%d\n",i,s[i]-48);			
		}else if(i%2==1){
			if((s[i]-48)*2>9){
				sum+=((s[i]-48)*2-9);
				printf("%d偶:%d\n",i,(s[i]-48)*2-9);
			}
			else{
				sum+=(s[i]-48)*2;
				printf("%d偶:%d\n",i,(s[i]-48)*2);
			}
		} 
	}
	printf("sum=%d\n",sum);
	if(sum%10==0)
	printf("成功\n");
	else
	printf("失败\n");
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值