明天要考CCF啦,偶还是很紧张的。最近看了数据结构,今天才开始上机练习,对,我就是这么懒。。废话不多说,我写这篇文章主要是分析CCF编程的小窍门,因为在网上没找到,所以我决定自力更生丰衣足食。!!!!
下面以第一次CCF考试的第二题为例说说我今天的小收获!!
 
问题描述

 
试题编号: 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号码分析的更多相关文章

  1. CCF 201312-2 ISBN号码 (水题)

    问题描述 每一本正式出版的图书都有一个ISBN号码与 之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后 ...

  2. [CCF] ISBN号码检测

    CCF ISBN号码检测 题目概述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其 ...

  3. CCF真题之ISBN号码

    201312-2 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上 ...

  4. CCF系列之ISBN号码(201312-2)

    试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规 ...

  5. CCF CSP 201312-2 ISBN号码

    题目链接:http://118.190.20.162/view.page?gpid=T4 问题描述 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0 ...

  6. CCF ISBN号码 201312-2

    ISBN号码 问题描述 试题编号: 201312-2 试题名称: ISBN号码 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 每一本正式出版的图书都有一个ISBN号码与之对应 ...

  7. NOIP2008 ISBN号码(一桶水)【A005】

    [A005]NOIP2008 ISBN号码(一大桶水)[难度A]———————————————————————————————————————————————————————————————————— ...

  8. 洛谷 P1055 ISBN号码【字符串+模拟】

    P1055 ISBN号码 题目描述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”就是分隔 ...

  9. CSP201312-2:ISBN号码

    引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试, ...

随机推荐

  1. python绝技 — 用Scapy测试无线网卡的嗅探功能

    代码 #!/usr/bin/python #--*--coding=utf-8--*-- from scapy.all import * def pktPrint(pkt): if pkt.hasla ...

  2. C#项目间循环引用的解决办法,有图有真相

    C#项目间循环引用的解决办法,有图有真相 程序间的互相调用接口,c#禁止互相引用,海宏软件,20160315 /// c#禁止互相引用,如果项目[订单]中有一个orderEdit单元,要在项目[进销存 ...

  3. 1、API

    基本API sectionsColor:['green','orange','red','grey'],//为每一层设置背景颜色 controlArrows:true,//是否显示幻灯片的左右按钮 v ...

  4. linux安装GraphicsMagick

    下载GraphicsMagick-1.3.21.tar.gz 解压:tar -zxvf GraphicsMagick-1.3.21.tar.gz cd /usr/local/GraphicsMagic ...

  5. mac xcode 快捷键

    shift + cmd + n     新建项目 cmd + n             新建文件 视图 option + cmd + 回车 打开助理编辑器 cmd + 回车           显示 ...

  6. FD.io vpp 框架转发图

    在ip4-icmp-input 与 ip4-udp-input后可以注册后续的处理函数,ip4-icmp-input根据 icmp的报文类型选择相应的处理函数,而ip4-udp-input根据端口选择 ...

  7. 浏览器exp使用经验

    0x00背景 windows平台下,浏览器安全是绕不过的话题,其涉及的安全问题涵盖二进制和web,攻击场景也非常多样化: 用户点击攻击者的恶意URL链接被感染恶意代码 访问恶意站点被绕过同源策略窃取c ...

  8. Android: Failure [INSTALL_FAILED_DEXOPT] and Failure [INSTALL_FAILED_UID_CHANGED] 解决方案

    1. 错误:  Failure [INSTALL_FAILED_DEXOPT]  Android安装App时 D:\WorkSpace\Administrator\workspace\svn\soot ...

  9. JAVA中方法的定义与使用(课堂学习归纳)

    组合数,百度词条是这样解释的:从m个不同元素中取出n(n≤m)个元素的所有组合的个数,叫做从m个不同元素中取出n个元素的组合数(Combination) 对于计算组合数,需要一定的工作量,计算机可以很 ...

  10. Centos安装vncserver服务

    vnc是一款Windows远程桌面软件,其优点是支持跨操作系统的远程图形化控制.下面开始记录第一次安装vnc服务的过程. 1.先检查系统是否有安装VNC服务 [root@localhost ~]# [ ...