C与C++中非常少犯的错误,犯了后却非常难找出的错误
1.continue,break类的错误(HDU1877)
:
#include<iostream>
using namespace std;
int main()
{
int a,b,m,sum;
while(cin>>m,m)
{
int p[100]={0};
cin>>a>>b;
sum=a+b;
if(!sum)//是0的话就不用再进行考虑了
{
cout<<0<<endl;
continue;//闲着没事,做个简单题,却由于忘了 continue 而 Presentation Error 了非常多次
}
int i=0;
while(sum)
{
p[i]=sum%m;
sum/=m;
i++;
}
for(int j=i-1;j>=0;j--)
cout<<p[j];
cout<<endl;
}
}
2.memset函数将数组初始化为1(from 百度文库
)
|
1
2
3
4
5
6
7
8
9
10
11
12
|
#include <iostream> |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include <iostream> |
memset还是按字节赋值,这样赋值完以后,每一个数组元素的值实际上是0x01010101即十进制的16843009。
3.while((c=cin.get())!='#')
本来想举个简单的样例。可是被这个坑得太慘了。所以。
。记住不是==,而是=。
c=getchar()一样。
#include<iostream>
#include<set>
#include<string>
using namespace std;
int main()
{
set<string> st;
string str;
char c;
str.clear();
while((c=cin.get())!='#')
{
while(c!=' '&&c!='\n')
{
str+=c;
c=cin.get();
}
if(str.length())
{
st.insert(str);
str.clear();
}
if(c=='\n')
{
cout<<st.size()<<endl;
st.clear();
str.clear();
}
}
return 0;
} <span style="font-size:18px;">
</span>
4.c++程序中。假设用#include<iostream>和cin的话。就避免不了使用名字空间。using namespace std;。。。我竟
然有一次删掉部分原来的代码又一次敲代码的时候,忘掉了写上了,结果浪费了好长时间(夹杂其它事),记住了这个教训。不止一次了.
5.已经定义了全局变量,还傻冒似的又定义了局部变量,结果覆盖了全局变量的作用,还不报错,非常少犯啊。,。非常难找出来啊,,,
6.scanf("%d%d%d",&t1,&t2,&t3,&t4); 少个%d居然不报错,居然少了,这就是依照曾经代码改动的坏处吧。改不好就呜呜了,加强能力
7.数学公式运算
pow运用于整数型会出错。由于除以会取整,要用浮点型才可能得到正确结果。
pow(10.0,num++);
8.关于数据范围的错误,so能尽量打就尽量大吧
#include<cstdio>
using namespace std;
long long a[100005]={0};
int main()
{
for(long long i=1;i<100002;i++)
{
if(i%3==0)
a[i]=a[i-1]+i*i*i;//i的3次方
else
a[i]=a[i-1]+i;
}
int n;
while(scanf("%d",&n)&&n>=0)
{
printf("%lld\n",a[n]);
}
return 0;
}
9.在for循环中使用strlen()函数,假设循环次数过多,就会导致超时,所以还是回归原始可靠的用变量定义吧。
採用
int len = strlen(str);
for(int i = 0;i < len;i++)
{ }
pass掉
for(int i = 0;i < strlen(str);i++)
{ }
C与C++中非常少犯的错误,犯了后却非常难找出的错误的更多相关文章
- Effective Objective-C 2.0 — 第二条:类的头文件中尽量少引入其他头文件
第二条:类的头文件中尽量少引入其他头文件 使用向前声明(forward declaring) @class EOCEmployer 1, 将引入头文件的实际尽量延后,只在确有需要时才引入,这样就可以减 ...
- DELPHI语法基础学习笔记-Windows 句柄、回调函数、函数重载等(Delphi中很少需要直接使用句柄,因为句柄藏在窗体、 位图及其他Delphi 对象的内部)
函数重载重载的思想很简单:编译器允许你用同一名字定义多个函数或过程,只要它们所带的参数不同.实际上,编译器是通过检测参数来确定需要调用的例程.下面是从VCL 的数学单元(Math Unit)中摘录的一 ...
- SQL中減少日志文件大小
SQL中減少日志文件大小 编写人:CC阿爸 2014-6-14 在日常SQL数据库的操作中,常常会出现SQL日志文件超大,大小都超过正常MDF数据库文件,作为一般用户来讲,LDF太大,只会影响服务 ...
- 在Spark中尽量少使用GroupByKey函数(转)
原文链接:在Spark中尽量少使用GroupByKey函数 为什么建议尽量在Spark中少用GroupByKey,让我们看一下使用两种不同的方式去计算单词的个数,第一种方式使用reduceByKey ...
- 关于在php中变量少写了一个$和页面不断转圈的问题排查和vim的自动补全方式
php中的所有变量都是页面级的, 即任何一个页面, 最多 都只能在一个文件 : 当前页面内使用, 不存在跨 文件/ 跨页面的 作用域的变量! 因此, 即使是 $GLOBALS 这个变量, 虽然叫全局 ...
- 集合的最大缺点是无法进行类型判定(这个缺点在JAVA1.5中已经解决),这样就可能出现因为类型不同而出现类型错误。
集合的最大缺点是无法进行类型判定(这个缺点在JAVA1.5中已经解决),这样就可能出现因为类型不同而出现类型错误. 解决的方法是添加类型的判断. LinkedList接口(在代码的使用过程中 ...
- 异步控制---实现函数asyncAll,在执行完传入数组中func1,func2,func3异步函数后,输出“end”
实现函数asyncAll,在执行完传入数组中func1,func2,func3异步函数后,输出"end" function func1(callback) { setTimeout ...
- HTML中head里的内容经浏览器解析后全到body里了
HTML中head里的内容经浏览器解析后全到body里了 修改完代码后,用chrome审查元素,head里的内容都到body中去了 http://bbs.csdn.net/topics/3802586 ...
- 在Eclipse中配置Tomcat时,出现Cannot create a server using the selected type错误
在eclipse中配置Tomcat时,出现Cannot create a server using the selected type错误 原因:Tomcat被删除或者是重新安装,并且安装目录改变了. ...
随机推荐
- IDA 显示函数名称技巧
http://blog.csdn.net/safedebug/article/details/17061735v
- 7款Flash和Javascript网页视频播放器
Flash和javascript网页视频播放器.梦想中的视频播放器是这样的: 支持所有格式,兼容所有主流视频网站,支持播放列表.视频缩略图.全屏播放.画面调节.预加载.体积贼小,功能贼多……. 也许你 ...
- 《C++反汇编与逆向分析技术揭秘》之十——构造函数
对象生成时会自动调用构造函数.只要找到了定义对象的地方,就找到了构造函数调用的时机.不同作用域的对象的生命周期不同,如局部对象.全局对象.静态对象等的生命周期各不相同,只要知道了对象的生命周期,便可以 ...
- Linux命令大全----系统管理相关命令
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要讲了Linux命令大全----系统管理相关命令,并附有实例 一.安装 ...
- 数学图形(1.38)anguinea曲线
个人觉得,这是一种变异的SIN曲线. #http://www.mathcurve.com/courbes2d/anguinee/anguinee.shtml vertices = t = from ( ...
- Android -- ListView与Adapter
ListView在Android中有着很重要的作用.Android开发中ListView是比较常用的组件,它以列表的形式展示具体内容,并且能够根据数据的长度自适应显示. 背景 ...
- 【云计算】OpenStack qcow2镜像如何转化为Docker镜像?
Import qcow2 image to docker hub 参考资料: https://forums.docker.com/t/import-qcow2-image-to-docker-hub/ ...
- HDU 2897 邂逅明下 (博弈)
题意: 给你n.p.q,每次操作是令n减小 [p, q]区间中的数,当n < p时必须全部取完了,取完最后一次的人算输,问先手必胜还是必败. 解题思路: 这种非常类似巴什博弈,可以找出必胜区间和 ...
- uva539 卡坦岛 简单回溯!
继续回溯搞起! 开始想复杂了,用了好多数组判断节点的度.边是否已经走过,结果导致超时了,后来简化成如下版本,走过的标志不需要另辟vis数组,只要将map[i][j]和map[j][i]赋值0即可. # ...
- keepalived的脑裂问题
keepalived的脑裂问题 学习了:http://blog.51cto.com/10630401/2089847 split-brain 无HA不脑裂