CSP-CCF 201312-2 ISBN号码

2024-08-22 09:36
文章标签 ccf csp 号码 isbn 201312

本文主要是介绍CSP-CCF 201312-2 ISBN号码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、题目

二、解答

方法1:char字符数组,但比较复杂的写法

方法2:char字符数组,相对简单的写法

方法3:

三、总结


一、题目

问题描述

  每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后一位是识别码,例如0-670-82162-4就是一个标准的ISBN码。ISBN码的首位数字表示书籍的出版语言,例如0代表英语;第一个分隔符“-”之后的三位数字代表出版社,例如670代表维京出版社;第二个分隔之后的五位数字代表该书在出版社的编号;最后一位为识别码。
  识别码的计算方法如下:
  首位数字乘以1加上次位数字乘以2……以此类推,用所得的结果mod 11,所得的余数即为识别码,如果余数为10,则识别码为大写字母X。例如ISBN号码0-670-82162-4中的识别码4是这样得到的:对067082162这9个数字,从左至右,分别乘以1,2,…,9,再求和,即0×1+6×2+……+2×9=158,然后取158 mod 11的结果4作为识别码。
  编写程序判断输入的ISBN号码中识别码是否正确,如果正确,则仅输出“Right”;如果错误,则输出是正确的ISBN号码。

输入格式

  输入只有一行,是一个字符序列,表示一本书的ISBN号码(保证输入符合ISBN号码的格式要求)。

输出格式

  输出一行,假如输入的ISBN号码的识别码正确,那么输出“Right”,否则,按照规定的格式,输出正确的ISBN号码(包括分隔符“-”)。

样例输入

0-670-82162-4

样例输出

Right

样例输入

0-670-82162-0

样例输出

0-670-82162-4

二、解答

方法1:char字符数组,但比较复杂的写法

#include<iostream>
#include<stdio.h>//用于getchar()
using namespace std;
int main()
{char a[15] = { NULL };int b[15] = { 0 };for (int i = 0; i < 13; i++){//两种输入方式//a[i] = getchar();cin >> a[i];	if (i != 1 && i != 5 && i != 11&&i!=12){b[i] = ((int)a[i])-48;}else {b[i] = 0;}}int sum = 0;//当需要累加计数时,该变量的初始化应该放在for循环外面,否则每次开始都是该初始值,没有达到想要的效果!!!int m = 1;//应该放在for循环外面,放在里面的话,每次都是1!!!不该犯的错误!!!耽误了好长时间!!!for (int i = 0; i < 11; i++){	if (i != 1 && i != 5){sum += b[i] * m;m++;}}if (a[12] == 'X'){if (sum % 11 == 10){cout << "Right" << endl;}else {a[12] = (char)((sum % 11)+48);for (int i = 0; i < 13; i++){//putchar(a[i]);cout << a[i];}}}else{if(sum%11==(((int)a[12])-48)){cout << "Right" << endl;}else{b[12] = sum % 11;if (b[12] == 10){a[12] = 'X';}else {a[12] = (char)(b[12]+48);}for (int i = 0; i < 13; i++){//putchar(a[i]);cout << a[i];}}}return 0;
}

方法2:char字符数组,相对简单的写法

#include<iostream>
#include<string>
using namespace std;
int main()
{char a[15];cin >> a;int num = 1;int sum = 0;for (int i = 0; i < 11; i++){if (a[i] >= '0' && a[i] <= '9'){sum += (a[i] - '0') * num;num++;}}if ((sum % 11 == 10 && a[12] == 'X') || (sum % 11 != 10 && sum % 11 == a[12] - '0')){cout<<"Right"<<endl;}else{a[12] = (sum % 11 == 10) ? 'X' : (sum%11 + '0');cout << a << endl;}return 0;
}

方法3:

也可以使用string来写,可以参考

https://zhuanlan.zhihu.com/p/661779756或者https://blog.51cto.com/u_15346485/5014875

三、总结

1.此题要用到char与int型的类型转换,特地搜索相关资料、写博客来总结了一些方法,可以查看博客:实用库/函数之类型转换-CSDN博客

2.搜索此题发现也可以用string,但是我之前没有深入学习过string,特地学习了一下,可以查看博客:实用库/函数之string的用法-CSDN博客

3.依然是那句话:细节,细节,一定要注重细节!!!

这篇关于CSP-CCF 201312-2 ISBN号码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1095899

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

CSP-J基础之数学基础 初等数论 一篇搞懂(一)

文章目录 前言声明初等数论是什么初等数论历史1. **古代时期**2. **中世纪时期**3. **文艺复兴与近代**4. **现代时期** 整数的整除性约数什么样的整数除什么样的整数才能得到整数?条件:举例说明:一般化: 判断两个数能否被整除 因数与倍数质数与复合数使用开根号法判定质数哥德巴赫猜想最大公因数与辗转相除法计算最大公因数的常用方法:举几个例子:例子 1: 计算 12 和 18

CCF推荐C类会议和期刊总结(计算机网络领域)

CCF推荐C类会议和期刊总结(计算机网络领域) 在计算机网络领域,中国计算机学会(CCF)推荐的C类会议和期刊为研究者提供了广泛的学术交流平台。以下是对所有C类会议和期刊的总结,包括全称、出版社、dblp文献网址以及所属领域。 目录 CCF推荐C类会议和期刊总结(计算机网络领域) C类期刊 1. Ad Hoc Networks 2. CC 3. TNSM 4. IET Com

CSP-J基础之数学基础 初等数论 一篇搞懂(二)

文章目录 前言算术基本定理简介什么是质数?举个简单例子:重要的结论:算术基本定理公式解释:举例: 算术基本定理的求法如何找出质因数:举个简单的例子: 重要的步骤:C++实现 同余举个例子:同余的性质简介1. 同余的自反性2. 同余的对称性3. 同余的传递性4. 同余的加法性质5. 同余的乘法性质 推论 总结 前言 在计算机科学和数学中,初等数论是一个重要的基础领域,涉及到整数

CSP-J基础之cmath常见函数

文章目录 前言1. **`sin` 函数**2. **`cos` 函数**3. **`exp` 函数**4. **`log` 函数**5. **`fabs` 函数**6. **`pow` 函数**7. **`sqrt` 函数**8. **`ceil` 函数**9. **`floor` 函数** 总结 前言 在计算机科学与编程中,数学函数是解决各种计算问题的基础工具。C++标准

CSP-J选择题 - 排列组合

排列问题:有5名学生参加比赛,要求排成一排拍照,有多少种不同的排列方式?组合问题:从10本书中选出3本书送给朋友,有多少种不同的选择方式?排列问题:一个教室有7个座位,5个学生需要坐下,有多少种不同的排列方式?组合问题:从12个人中选出4个人组成一个团队,有多少种不同的方式?排列问题:一个密码由4个字母组成,字母可以重复使用,有多少种不同的排列组合?组合问题:从8个不同颜色的球中选出3个,不考虑顺

CSP-J 之C++常用英文缩写

文章目录 C++常用英文缩写前言常用缩写解析C++ 基础缩写输入输出相关控制台 命名与类型常用函数在线测评相关 总结 C++常用英文缩写 前言 在编程比赛和日常开发中,C++是一门广泛使用的编程语言,许多英文缩写贯穿其中。了解这些缩写不仅有助于提高编程效率,还能加深对编程语言及其工作机制的理解。本文将介绍C++中常见的英文缩写,以及它们在编程中的实际含义和应用。 常用

PHP 验证身份号码 包括15位18位

查了很多资料 发现网上身份证15位的验证并不是那么严谨  今天研究了一下  代码如下 <?phpfunction check_id_card($num){//老身份证长度15位,新身份证长度18位$length = strlen($num);if ($length == 15) { //如果是15位身份证//15位身份证没有字母if (!is_numeric($num)) {return fa

P7072 [CSP-J2020] 直播获奖

题目描述     NOI2130即将举行。为了增加观赏性,CCF决定逐一评出每个选手的成绩,并直播即时的获奖分数线。本次竞赛的获奖率为w% 的选手的最低成绩就是即时的分数线。     更具体地,若当前已评出了 p 个选手的成绩,则当前计划获奖人数为max(1,⌊p∗w%⌋),其中w是获奖百分比,⌊x⌋ 表示对x向下取整,max(x,y) 表示x和y中较大的数。如有选手成绩相同,则所有成绩并列的