明天要考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. CodeForces 708B Recover the String

    构造. 根据$a[0][0]$可以求得$0$的个数$p$,根据$a[1][1]$可以求得$1$的个数$q$. 如果找不到$p$或$q$,那么就无解. 每一个$0$放到序列中的任何一个位置,假设和前面的 ...

  2. CodeForces 706C Hard problem

    简单$dp$. $dp[i][0]$:第$i$个串放置完毕,并且第$i$个串不反转,前$i$个串字典序呈非递减的状态下的最小费用. $dp[i][1]$:第$i$个串放置完毕,并且第$i$个串反转,前 ...

  3. 编译C语言单元测试框架CUnit库的方法

    引用: http://blog.csdn.net/yygydjkthh/article/details/46357421 个人备忘使用 /******************************* ...

  4. hdu 3415 Max Sum of Max-K-sub-sequence(单调队列)

    题目链接:hdu 3415 Max Sum of Max-K-sub-sequence 题意: 给你一串形成环的数,让你找一段长度不大于k的子段使得和最大. 题解: 我们先把头和尾拼起来,令前i个数的 ...

  5. ASP.NET 企业组织机构代码验证

    /// <summary> /// 组织机构代码验证 /// </summary> /// <param name="arg"></par ...

  6. php笔记(八)PHP类与对象之抽象类

    <?php //通过abstract关键字定义一个抽象类 abstract class ACanEat{ //通过abstract关键字定一个不用具体实现的抽象方法eat() abstract ...

  7. 【简单并查集】Farm Irrigation

    Farm Irrigation Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Tot ...

  8. i++与++i区别使用

    中心:使用变量自增或者处减使用尽量使用++i与--i,而不要去使用i++与i-- ++i与--i可以做左值也可以做右值,而i++与i--只能做右值. 对于基础类型i++与++i结果相同,但是i++肯定 ...

  9. 自己通过反射写的一个属性copy类

    package com.xxx.beancopier; import java.lang.annotation.Documented; import java.lang.annotation.Elem ...

  10. JavaScript DOM编程艺术-学习笔记(第十章、第十一章)

    第十章 1.动画中,因为js的效率高,所以看不见过渡效果 2.题外话:①国外人写书,总是先感谢一遍亲朋好友,最后感谢自己的家人. 3."除非允许用户'冻结'移动的内容,否则应该避免让内容在页 ...