201312月CCF-2,ISBN号码分析
| 试题编号: | 201312-2 |
| 试题名称: | ISBN号码 |
| 时间限制: | 1.0s |
| 内存限制: | 256.0MB |
| 问题描述: |
问题描述
每一本正式出版的图书都有一个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
|
题目是这样的,很简单吧。然而。。。。。。。
#include "stdio.h"
#include "stdlib.h"
int main()
{
int i=0,j,x,a=0;
char c,x1;
char A[10];
for(j=1;j<=13;j++)
{
scanf("%c",&c);
if(j!=2&&j!=6&&j!=12)
A[i++]=c;
}
for(j=0;j<=8;j++)
{
a+=(A[j]-'0')*(j+1);
}
x=a%11;
x1=x+48;
if(A[9]==x1||(A[9]=='X'&&x==10))
printf("Right");
else
{
i=0;j=1;
for(j=1;j<=12;j++)
{
if(j==2||j==6||j==12)
printf("-");
else
printf("%c",A[i++]);
}
printf("%d",x);
}
system("pause");
return 0;
}
在devc++上运行正确,可是提交之后系统显示分数是:0.0。郁闷。
我最后改了好多次,终于,当代吗变成这样的时候:
#include "stdio.h"
#include "stdlib.h"
#define MaxSize 100
int main()
{
int i=0,j=1,x,a=0;
char c,x1;
char A[10];
while(j<=13)
{
scanf("%c",&c);
if(j!=2&&j!=6&&j!=12)
A[i++]=c;
j++;
}
j=0;
while(j<=8)
{
a+=(A[j]-'0')*(j+1);
j++;
}
x=a%11;
x1=x+48;
if(A[9]==x1||(A[9]=='X'&&x==10))
printf("Right");
else
{
i=0;j=1;
while(j<=12)
{
if(j==2||j==6||j==12)
printf("-");
else
printf("%c",A[i++]);
j++;
}
printf("%d",x);
}
system("pause");
return 0;
}
这下系统显示的分数是70.0/100。对比一下,就是把所有的for()循环写成while()循环,没什么其他变化。
在练习过程中,小编我发现:
1,最好用int main(){
..............
sysytem("pause");
return 0;
}这种形式。否则很可能系统编译出错。。。。。。
2,代码中不要出现getchar(),strlen()这种函数,就用最基本的C/C++的句子写就好;
3,循环尽量用while(),不用for();
4,不仅要注意算法的时间复杂度,也要注意代码的空间复杂度;
5,注意代码细节,比如 i++;和 i=i+1;谁更快,这种基本的问题+_+晕;
做了几道题,也没摸准CCF的评分标准,不过能肯定的是,考的都是一些细节。看到大神们考几十分,或者几百分,还有人说九分靠运气,一分靠实力。不过我觉得多练习肯定是好哒!!
好了,说到这儿了,希望明天顺利顺利!!渣渣求保佑!!
201312月CCF-2,ISBN号码分析的更多相关文章
- CCF 201312-2 ISBN号码 (水题)
问题描述 每一本正式出版的图书都有一个ISBN号码与 之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后 ...
- [CCF] ISBN号码检测
CCF ISBN号码检测 题目概述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其 ...
- CCF真题之ISBN号码
201312-2 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上 ...
- CCF系列之ISBN号码(201312-2)
试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规 ...
- CCF CSP 201312-2 ISBN号码
题目链接:http://118.190.20.162/view.page?gpid=T4 问题描述 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0 ...
- CCF ISBN号码 201312-2
ISBN号码 问题描述 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应 ...
- NOIP2008 ISBN号码(一桶水)【A005】
[A005]NOIP2008 ISBN号码(一大桶水)[难度A]———————————————————————————————————————————————————————————————————— ...
- 洛谷 P1055 ISBN号码【字符串+模拟】
P1055 ISBN号码 题目描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”就是分隔 ...
- CSP201312-2:ISBN号码
引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试, ...
随机推荐
- angular学习笔记
1.forEach arr:参数是key,index json:与jquery相反,参数是value,key2.str-->json JSON.parse() ang ...
- jQuery Validate【强大的表单验证】
一.引入菜鸟教程提供的 1.14.0 版本下载地址:http://static.runoob.com/download/jquery-validation-1.14.0.zip <script ...
- html的简单表单制作...day5 php
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Q & A
1 使用linux命令或者shell实现:文件words存放英文单词,格式为每行一个英文单词(单词可以重复),统计这个文件中出现次数最多的前10个单词. cat words.txt | sort | ...
- python 基础学习-总结1
1.Python 简介 易学易懂,语法简单 不需编译,即可运行 比其他语言更简洁 不需要管理内存 1.1 什么是Python? python 是由Guido.van.Rossum于1989年始创,其根 ...
- 属性动画(Property Animation)
属性动画系统是一个强大的可以绘制任意事物.你可以定义改变物体属性的动画,不管它是不是在屏幕上.属性动画随着时间的推移去改变物体的属性.如果要让某个事物动起来,你只需指定该事物的某个属性,如物体的坐标. ...
- java中异常处理机制的简单原理
以上是自认为的java异常处理的简单原理,如有不妥之处还请各位大神帮忙指点,谢谢!
- 快速挂载和分离VHD文件的小脚本
=======代码开始======== echo select vdisk file= %VHD文件路径% echo attach vdisk exit 分离VHD的脚本,只需要将上述代码中 at ...
- Oracle中 union 和 union all 的区别
如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字. union(或称为联合)的作用是将多个结果合并在一起显示出来. union和uni ...
- nagios监控mysql主从状态
看了网上很多mysql主从监控的,大部分都是shell的,就算是python的,也是在python下跑shell语句.我写了一个python的监控脚本,用到了mysqldb这个包.脚本如下: [roo ...