见:C语言初学者代码中的常见错误与瑕疵(23)…
问题: 问题出处见 C语言初学者代码中的常见错误与瑕疵(5) . 在该文的最后,曾提到完成的代码还有进一步改进的余地.本文完成了这个改进.所以本文讨论的并不是初学者代码中的常见错误与瑕疵,而是对我自己代码的改进和优化.标题只是为了保持系列的连续性. 改进 程序的总体思想没有改变,所以main()函数不需要任何改动. int main( void ) { unsigned n ; puts( "数据组数=?" ); scanf( "%u" , &n ); )…
问题: 素数 在世博园某信息通信馆中,游客可利用手机等终端参与互动小游戏,与虚拟人物Kr. Kong 进行猜数比赛. 当屏幕出现一个整数X时,若你能比Kr. Kong更快的发出最接近它的素数答案,你将会获得一个意想不到的礼物. 例如:当屏幕出现22时,你的回答应是23:当屏幕出现8时,你的回答应是7: 若X本身是素数,则回答X;若最接近X的素数有两个时,则回答大于它的素数. 输入:第一行:N 要竞猜的整数个数 接下来有N行,每行有一个正整数X 输出:输出有N行,每行是对应X的最接近它的素数 样例…
见:C语言初学者代码中的常见错误与瑕疵(19)…
见:C语言初学者代码中的常见错误与瑕疵(14) 相关链接:http://www.anycodex.com/blog/?p=87…
前文链接:分数的加减法——C语言初学者代码中的常见错误与瑕疵(11) 重构 题目的修正 我抛弃了原题中“其中a, b, c, d是一个0-9的整数”这样的前提条件,因为这种限制毫无必要.只假设a, b, c, d是十进制整数形式的字符序列. 我也不清楚这种题目应该如何结束输入.下面的代码假设在没有正确输入完整的运算式时结束. 数据结构 typedef struct { int numer ; //分子 int denom ; //分母 } frac_t ;//分数类型 数据 一共需要三个变量,两…
题目 字母的个数 现在给你一个由小写字母组成字符串,要你找出字符串中出现次数最多的字母,如果出现次数最多字母有多个那么输出最小的那个. 输入:第一行输入一个正整数T(0<T<25) 随后T行输入一个字符串s,s长度小于1010. 输出:每组数据输出占一行,输出出现次数最多的字符: 样例: 输入 3 abcd bbaa jsdhfjkshdfjksahdfjkhsajkf 输出: a a j 原代码 #include <stdio.h> #include <string.h&g…
在 C语言初学者代码中的常见错误与瑕疵(7) 中,我给出的重构代码中存在BUG.这个BUG是在飞鸟_Asuka网友指出“是不是时间复杂度比较大”,并说他“第一眼看到我就想把它当成一个数学问题来做”之后,我又重新对问题进行了数学式的思考后发现的. 这个BUG源于在(1<=A,B<=1000)条件下对矩形个数的数量级心里没数.当时觉得这个题目的目的是考察穷举,由于题目限定了A.B的范围,所以结果应该不是很大.事实证明这种想法是一厢情愿. 通常情况下,我不喜欢用数学方法解决C语言编程问题.因为很多问…
问题: 矩形的个数 在一个3*2的矩形中,可以找到6个1*1的矩形,4个2*1的矩形3个1*2的矩形,2个2*2的矩形,2个3*1的矩形和1个3*2的矩形,总共18个矩形.给出A,B,计算可以从中找到多少个矩形 输入: 本题有多组输入数据(<10000),你必须处理到EOF为止 输入2个整数A,B(1<=A,B<=1000) 输出: 输出找到的矩形数. 样例: 输入: 1 2 3 2 输出: 3 18 原代码-1: #include <stdio.h> int rectang…
曾在豆瓣上看到过一个小朋友贴出他自己的代码(http://www.douban.com/group/topic/40293109/),当时随口指点了几句.难得这位小朋友虚心修正.从善如流,不断地改,又不断地贴,坚持了很久.到后来这位小朋友的代码已经大有长进. 这位小朋友犯过的很多错误都非常典型,在初学者中非常普遍,于是整理了一下,应该对其他初学者有借鉴意义. 问题 开灯问题 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有…