鱼C论坛

 找回密码
 立即注册
查看: 2309|回复: 5

[已解决]大一C语言编程题求助

[复制链接]
发表于 2020-4-30 00:50:09 | 显示全部楼层 |阅读模式

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

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

x
题目描述
有一个字符串均由数字组成,我们规定该字符串的校验和的计算方法为,首先把每一位上的数字都乘以一个权值,然后把所得到的这些乘积再加起来,得到一个和,最后用这个和模除23即得到了校验和。其中各位的权值为:从低位向高位数,假设某位为第n位,则当n模除17为0时,权值为13, 则当模n除17为1时,权值为16, 则当模n除17为2时,权值为30, 则当n模除17为3时,权值为17, 则当n模除17为4时,权值为8, 则当模n除17为5时,权值为24, 则当n模除17为6时,权值为21, 则当模n除17为7时,权值为3, 则当模n除17为8时,权值为9, 则当模n除17为9时,权值为12, 则当n模除17为10时,权值为10, 则当n模除17为11时,权值为4, 则当n模除17为12时,权值为6, 则当n模除17为13时,权值为14, 则当n模除17为14时,权值为15, 则当n模除17为15时,权值为29, 则当n模除17为16时,权值为11。现请你写一段程序来计算这个校验和。

输入:
只有一行,为一个长度不超过1000且仅包含数字的字符串。

输出:
为上述规则下该字符串的校验和。测试用例保证所有整数可以用 int存储。


输入样例
85302688978758327
输出样例
21


刚接触C语言,完全没有思路,希望大佬们能帮帮忙!
最佳答案
2020-4-30 10:10:53
本帖最后由 sunrise085 于 2020-4-30 10:12 编辑
#include<stdio.h>
#include<string.h>
int check(char *string){
    int i=0,length,sum=0,a[17]={13,16,30,17,8,24,21,3,9,12,10,4,6,14,15,29,11};
    length=strlen(string);
    for (i=length-1;i>=0;i--){
        sum+=(string[i]-'0')*a[(length-i)%17];
    }
    return sum%23;
}
int main()
{
    int i=0,result;
    char ch,string[1001];
    
    printf("请输入您的需要校验的数字:");
    while ((ch=getchar())!='\n'&& i<1001){
        string[i++]=ch;
    }
    string[i]='\0';
    result=check(string);
    printf("校验结果为:%d\n",result);
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-30 07:47:02 From FishC Mobile | 显示全部楼层
@人造人
话说,没看懂,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-30 09:11:27 | 显示全部楼层
这不就是二代身份证的校验码计算方式么?
从低位向高位数,假设某位为第n位,

哪边是低位?
输入样例
85302688978758327

低位是8还是7?
题目不难吧。网上多得是。
找个二代身份证校验程序代码修改一下就行了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-30 10:10:53 | 显示全部楼层    本楼为最佳答案   
本帖最后由 sunrise085 于 2020-4-30 10:12 编辑
#include<stdio.h>
#include<string.h>
int check(char *string){
    int i=0,length,sum=0,a[17]={13,16,30,17,8,24,21,3,9,12,10,4,6,14,15,29,11};
    length=strlen(string);
    for (i=length-1;i>=0;i--){
        sum+=(string[i]-'0')*a[(length-i)%17];
    }
    return sum%23;
}
int main()
{
    int i=0,result;
    char ch,string[1001];
    
    printf("请输入您的需要校验的数字:");
    while ((ch=getchar())!='\n'&& i<1001){
        string[i++]=ch;
    }
    string[i]='\0';
    result=check(string);
    printf("校验结果为:%d\n",result);
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-30 12:47:56 | 显示全部楼层
wp231957 发表于 2020-4-30 07:47
@人造人
话说,没看懂,

我能理解,而且 sunrise085 也解释的很好了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-30 19:18:58 | 显示全部楼层
sunrise085 发表于 2020-4-30 09:11
这不就是二代身份证的校验码计算方式么?

哪边是低位?

最右是低位,但还是看懂了,谢谢大佬!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-11 18:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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