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 百度文库)
如下demo是可以的,能把
数组中的元素值都设置成字符1,
1
2
3
4
5
6
7
8
9
10
11
12
|
|
而,如下程序想把数组中的元素值设置成1,却是不可行的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
|
问题是:
1.第一个程序为什么可以,而第二个不行?
因为第一个程序的数组a是
字符型的,字符型占据内存大小是1Byte,而memset函数也是以
字节为单位进行赋值的,所以你输出没有问题。而第二个程序a是整型的,使用 memset还是按字节赋值,这样赋值完以后,每个数组元素的值实际上是0x01010101即十进制的16843009。
如果用memset(a,1,20),就是对a指向的内存的20个字节进行赋值,每个都用数1去填充,转为二进制后,1就是00000001,占一个字节。一个int元素是4字节,合一起是0000 0001,0000 0001,0000 0001,0000 0001,转化成十六进制就是0x01010101,就等于16843009,就完成了对一个int元素的赋值了。
3. while((c=cin.get())!='#')
本来想举个简单的例子,但是被这个坑得太惨了,所以。。记住不是==,而是=。c=getchar()一样。
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++)
{
}