您的位置:首页 > 编程语言

吾程序猿一路编程过程中遇到的各种奇葩(或粗心不懂,或源于ACM)不断更新ing..........

2013-02-16 19:20 246 查看
4-28:五一自己要奋斗好多东西,别太多lOL,还尼玛撸的郁闷。

稍一不编程,手、脑袋就生,比如Input.txt................

4-29:实在是差距挺大,加油吧!!

GF的言论:1.身为coder,浮躁永远要不得,谨慎缜密永远压于自以为是的正确...相信事实....

2.大牛无非三种人@@

3.牛人在很多OJ都不经意地做过几百题,而且题目技术含量普遍比较高,稍微菜一点的刷题户基本上就死盯一个大型OJ弄上他近千题,以刷水题提升排名为主切难题提升实力为辅(转的,说的还算有点对吧...)

4.编程是练出来的....由白书的代码理解后自己敲一遍;不放纵,不浮躁哈...这是理解的比较好的方法,然后相应UVA上面的题,想一日千里也不太现实!

5.自己和别人的差距(神马名校了)的确是很大的...至少没有那种氛围、压力、资源,况且又不是你一个人在战斗!

6.其实感觉ACM真的很爽呃...那种比赛的氛围环境与实力的比拼!

7.书上得来终觉浅,绝知此事就亲打...

8.OJ上提交得注意点,习惯冲动性改一个地方交一次,2-22 1162来了三次超时,我于是明白,吾算法不精,太莽撞.......

9.TY大牛说了一般没有线下打表的题....果然自己code不精....

关于sqrt()
1.1.#INF / inf:这个值表示“无穷大 (infinity 的缩写)”,即超出了计算机可以表示的浮点数的最大范围(或者说超过了 double 类型的最大值)。例如,当用 0 除一个整数时便会得到一个1.#INF / inf值;相应的,如果用 0 除一个负整数也会得到 -1.#INF / -inf 值。
-1.#IND / nan:这个的情况更复杂,一般来说,它们来自于任何未定义结果(非法)的浮点数运算。"IND"是 indeterminate 的缩写,而"nan"是 not a number 的缩写。产生这个值的常见例子有:对负数开平方,对负数取对数,0.0/0.0,0.0*∞, ∞/∞ 等。简而言之,如果遇到 1.#INF / inf,就检查是否发生了运算结果溢出除零,而遇到 1.#IND / nan,就检查是否发生了非法的运算。
2.sqrt(-10)=0
3.同理1.0/0.0 0.0/0.0
4.可是%d返回0 编译器不会报错
5.1/0系统就崩溃!
5.sqrt是返回double型

关于输出
1.printf("%%d\\n"); 一般情况下的字符转义是用\但是%比较特殊,用%进行转义。

关于实践求Int double的表示范围
1.2147483647 2的31次方-1
-2147483648
double型那就是64次方了呗。。2013-02-16

数据类型如果有n个bits,那么表示范围就是:-2^n - 2^n-1
例如:
byte(8 bits): -2^7 - 2^7-1
short(16 bits): -2^15 - 2^15-1
int(32 bits): -2^31 - 2^31-1
long(64 bits): -2^63 - 2^63-1

int int_min()
{
int n=0,i=0;
while(n>=i)
{
n=i;
i--;
}
return n;
}

int int_max()
{
int n=0,i=0;
while(n<=i)
{
n=i;
i++;
}
return n;
}

关于绝对值函数
abs( int x )是求整数的绝对值的 , fabs( double x )是精确到双精度浮点型的求绝对值的 ,简单的说就是保留的精度位数更高

以后测试实验数据都用重定向呗
freopen("input.txt","r",stdin);
freopen("output.txt","w",stdout);

吾终于明白输出格式是多么的重要了 擦!!
一个换行或空格少了多了都不行...

东大判断回文数

#include<stdio.h>
#include<string.h>
int main()
{
char str[200];
int len,i,shit;
freopen("input.txt","r",stdin);
freopen("output.txt","w",stdout);
while(scanf("%s",str)!=EOF)
{
shit=0;//这一步丢了可惜
len=strlen(str);
for( i=0;i<len/2;i++)
if(str[i]!=str[len-1-i])
{
shit=1;
break;
}
if(shit==1)
printf("NO");
else printf("YES");
printf("\n");
}
return 0;
}
//现在回文数用sprintf最简单 以后也这么做


每一次都要重置0!!!
而不能把0置在循环语句外... 重定向一不小心就忘删了 (永不陷入消极情绪!)
一般最后打上“\n” 还有一定要题目中输入输出的一模一样,包括大小写神马的,杨哲学长出的那几道题真让我这个菜鸟明白了哈哈!!

scanf("%%")是读写时加%
养成提交OJ时再稍看一眼的习惯,避免一些低级错误,如重定向,神马的

我的getchar函数应用也存在漏洞???? 带缓冲
getchar 的用途是从从标准输入流读取一个字符,读回车符时退出getchar();永远只向缓存中输入一个字符, getchar();的用法很多; 一种就是清空回车符 这种情况一般发生在在循环中涉及到输入的情况 还有一种是某些编译平台(IDE)在运行程序时并没有在程序运行后给人看结果的时间 这时候 在程序最后加上getchar()就能造成程序的暂停 给程序员度结果的机会用getchar时,在键盘上按一个字符后,要按回车才能读取进去;用getch时,在键盘上按一个字符马上就被读取进去,不用按回车,因此可以作为“按任意键继续”的执行语句

我是越来越相信WA是一定有BUG的了 这种事情一旦返回了个WA 就马上考虑自己的错误 绝不会有任何郁闷心理“哎,没错呀”之类

辗转相除法递归求最大公约数其实还不会呀
OJ前再浏览一遍看一下有没有垃圾错误。。

百度大神帮忙哈~~~

int gcd(int a,int b)
{
if (0 == a*b)
return a+b;
if(a%b==0) return b;//这地方有缺陷的 如果b是a的倍数 嗯确定自己的粗心 而不是没有原因的错哈
else
{
if(a>b)
return gcd(b,a%b);
if(a<b)
gcd(a,b%a);
}
}
//以后应该这样 看我一行代码解决gcd
int gcd(int a,int b)
{
return b==0?a:gcd(b,a%b);
}


OJ上也可以通过时间 长度 内存来大致看一下这道题目自己应如何把握

C语言字符数组结束不加‘\0’结果可能出现些狗屎符号

---恢复内容结束---

关于sqrt()
1.1.#INF / inf:这个值表示“无穷大 (infinity 的缩写)”,即超出了计算机可以表示的浮点数的最大范围(或者说超过了 double 类型的最大值)。例如,当用 0 除一个整数时便会得到一个1.#INF / inf值;相应的,如果用 0 除一个负整数也会得到 -1.#INF / -inf 值。
-1.#IND / nan:这个的情况更复杂,一般来说,它们来自于任何未定义结果(非法)的浮点数运算。"IND"是 indeterminate 的缩写,而"nan"是 not a number 的缩写。产生这个值的常见例子有:对负数开平方,对负数取对数,0.0/0.0,0.0*∞, ∞/∞ 等。简而言之,如果遇到 1.#INF / inf,就检查是否发生了运算结果溢出除零,而遇到 1.#IND / nan,就检查是否发生了非法的运算。
2.sqrt(-10)=0
3.同理1.0/0.0 0.0/0.0
4.可是%d返回0 编译器不会报错
5.1/0系统就崩溃!
5.sqrt是返回double型

关于输出
1.printf("%%d\\n"); 一般情况下的字符转义是用\但是%比较特殊,用%进行转义。

关于实践求Int double的表示范围
1.2147483647 2的31次方-1
-2147483648
double型那就是64次方了呗。。

数据类型如果有n个bits,那么表示范围就是:-2^n - 2^n-1
例如:
byte(8 bits): -2^7 - 2^7-1
short(16 bits): -2^15 - 2^15-1
int(32 bits): -2^31 - 2^31-1
long(64 bits): -2^63 - 2^63-1

int int_min()
{
int n=0,i=0;
while(n>=i)
{
n=i;
i--;
}
return n;
}

int int_max()
{
int n=0,i=0;
while(n<=i)
{
n=i;
i++;
}
return n;
}

关于绝对值函数
abs( int x )是求整数的绝对值的 , fabs( double x )是精确到双精度浮点型的求绝对值的 ,简单的说就是保留的精度位数更高

以后测试实验数据都用重定向呗
freopen("input.txt","r",stdin);
freopen("output.txt","w",stdout);

吾终于明白输出格式是多么的重要了 擦!!
一个换行或空格少了多了都不行...

东大判断回文数
#include<stdio.h>
#include<string.h>
int main()
{
char str[200];
int len,i,shit;
freopen("input.txt","r",stdin);
freopen("output.txt","w",stdout);
while(scanf("%s",str)!=EOF)
{
shit=0;//这一步丢了可惜
len=strlen(str);
for( i=0;i<len/2;i++)
if(str[i]!=str[len-1-i])
{
shit=1;
break;
}
if(shit==1)
printf("NO");
else printf("YES");
printf("\n");
}
return 0;
}
每一次都要重置0!!!
而不能把0置在循环语句外... 重定向一不小心就忘删了 (永不陷入消极情绪!)
一般最后打上“\n” 还有一定要题目中输入输出的一模一样,包括大小写神马的,杨哲学长出的那几道题真让我这个菜鸟明白了哈哈!!

scanf("%%")是读写时加%
养成提交OJ时再稍看一眼的习惯,避免一些低级错误,如重定向,神马的

我的getchar函数应用也存在漏洞???? 带缓冲
getchar 的用途是从从标准输入流读取一个字符,读回车符时退出getchar();永远只向缓存中输入一个字符, getchar();的用法很多; 一种就是清空回车符 这种情况一般发生在在循环中涉及到输入的情况 还有一种是某些编译平台(IDE)在运行程序时并没有在程序运行后给人看结果的时间 这时候 在程序最后加上getchar()就能造成程序的暂停 给程序员度结果的机会用getchar时,在键盘上按一个字符后,要按回车才能读取进去;用getch时,在键盘上按一个字符马上就被读取进去,不用按回车,因此可以作为“按任意键继续”的执行语句

我是越来越相信WA是一定有BUG的了 这种事情一旦返回了个WA 就马上考虑自己的错误 绝不会有任何郁闷心理“哎,没错呀”之类

辗转相除法递归求最大公约数其实还不会呀
OJ前再浏览一遍看一下有没有垃圾错误。。

百度大神帮忙哈~~~
int gcd(int a,int b)
{
if (0 == a*b)
return a+b;
if(a%b==0) return b;//这地方有缺陷的 如果b是a的倍数 嗯确定自己的粗心 而不是没有原因的错哈
else
{
if(a>b)
return gcd(b,a%b);
if(a<b)
gcd(a,b%a);
}
}

OJ上也可以通过时间 长度 内存来大致看一下这道题目自己应如何把握

C语言字符数组结束不加‘\0’结果可能出现些狗屎符号]

要想用freopen 得加上#include<stdio.h>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: