201312月CCF-2,ISBN号码分析

明天要考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的评分标准,不过能肯定的是,考的都是一些细节。看到大神们考几十分,或者几百分,还有人说九分靠运气,一分靠实力。不过我觉得多练习肯定是好哒!!

好了,说到这儿了,希望明天顺利顺利!!渣渣求保佑!!

上一篇:Android中JNI编程的那些事儿(1)


下一篇:6、Django实战第6天:用户登录