- 1、本文档共31页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
简单的ACM程序技巧
ACM程序设计技巧
王 璐
中原工学院计算机学院
2009-12
目录
输入Input
输出Output
编译器的差别
程序编写
题目阅读理解
ACM题目中的输入输出
ACM竞赛题目包括三个部分
Description
Input
Output
Input和Output给出了输入输出的格式、数量等
要求,并且要求严格遵循要求。
格式等完全与要求一致,包括空格、回车等
不允许任何额外的(例如对话或调试用的)输入输出
必须认真研读Input和Output的要求(借助字典)。
Sample Input和Sample Output有助于理解题目,但也
会包含一些理解问题的陷阱,因此必须仔细读要求。
例:中科大problem 1002
ACM题目中的输入输出
Why要求严格?
在线评判系统Online Judge (OJ)中,一道题目的所有
测试数据是放在一个文本文件里的。
程序从该文件中读取测试数据如果不按照要求,就有
可能读错误数据。
再把运行结果输出到另一个文本文件中。
系统把输出文件与标准答案进行自动比对,来评判程序编写
得正确与否。即,如果有一点错误,就会判断“Wrong Answer”
但我们编程时不用关心OJ的读写是怎么实现的,只要
按题目要求面向标准输入输出设备(即键盘和显示
器)写输入输出语句就可以了。
为避免此类错误,必须仔细深入地研究输入输出问
题。
输入Input
四种形式
不说明有多少组输入数据
即题目没有告诉你有多少组数据。这个通常是最令新手疑惑
的。这种情况,一般用文件结束标志EOF判断,即直到读至输
入文件末尾为止 。
固定组数的输入,即在开始的时候输入一个N,接下来
是N组数据。
输入不说明有多少组数据,但以某个特殊输入为结束
标志。
其它情况
只有1组数据。
不说明有多少组输入数据
例:
不说明有多少组输入数据
程序
说明:
EOF是一个预定义的常量,等于-1,通常指文件末尾。由于acm竞赛
的测试数据一般放在一个输入文件里,所以可以判断是否完成所有
输入数据。如果在控制台,则输入ctrl+z (组合键)(linux下是
ctrl+d ),终止输入。
scanf函数返回值就是读出的变量个数,如:scanf( “%d %d”, a,
b );如果只有一个整数输入,返回值是1,如果有两个整数输入,返
回值是2,如果一个都没有,则返回值是-1 。
关于输入函数scanf、getchar()、cin
标准语法分析
scanf 执行格式化输入
int scanf(char *format[,argument,...])
例:scanf(%d%d, a, b);
如果a和b都被成功读入,那么scanf的返回值就是2
如果只有a被成功读入,返回值为1
如果a和b都未被成功读入,返回值为0
如果遇到end of file,返回值为EOF。
getchar 从stdin流中读字符
int getchar(void);
由于有可能返回EOF,因此接收变量需要声明为int
文档评论(0)