数组初始化
目录
数组定义不初始化会被随机赋值
数组初始化的几种形式
数组初始化为某一固定值
fill(begin(),end(),value)
以前刚开始学数组初始化,一直都没搞太清楚,包括参加PAT考试,直到看了胡凡的《算法笔记》,逐渐清晰,是这样的:
-
数组定义不初始化会被随机赋值
因此如果数组的所有元素在下面没有逐一赋值,但是又会使用到的话,最后不要只定义而不初始化。会带来问题。
-
数组初始化的几种形式
- 可以直接用{}:a[10]={},就可以让a[10]数组中的所有元素全为0;
- 也可以{}内包含0:a[10]={},也可以让a[10]数组中的所有元素全为0;
- {}内写一个值只会让第一个元素为这个值,后面的依旧是0:a[3]={5},数组实际上被初始化为{5,0,0}
-
数组初始化为某一固定值
可以将数组初始化为某一固定值。有两种方法,一种是使用<string>(C++)或<string.h>(C)中的memset()函数,还有一种是使用<algorithm>中的fill()函数,fill函数可以初始化容器和数组。
-
memset(数组名,值,sizeof(数组名))
只建议使用memset()的时候初始化为0或者-1。menset()函数的功能性不如fill()函数,其优点在于执行速度更快。
程序实例:
#include <stdio.h>
int main(){
int a[10];
memset(a,5,sizeof(a));
for(int i=0;i<10;i++)
printf("%d",a[i]);
return 0;
}
//output:5555555555
-
fill(begin(),end(),value)
fill()可以把数组和容器中的某一段区间赋值为某个相同的值。和memset()不同的是这里的赋值可以是数组类型对应范围中的任意值。
程序实例:
#include <iOStream>
#include <algorithm>
using namespace std;
int main(){
int a[10];
fill(a,a+5,233);
for(int i=0;i<10;i++)
cout<<a[i]<<" ";
return 0;
}
/*
233 233 233 233 233 0 31 0 0 0
--------------------------------
Process exited after 0.4914 seconds with return value 0
请按任意键继续. . .
*/
从这里也可以看出,a[]后面的元素是随机赋值的。
建议采用fill()而不是使用memset()。
相关阅读
VC6.0和VS2010最大的区别在于默认的字符集,VC6.0默认的字符集为ANSI,而VS2010默认的字符集为UNICODE.这就造成了,VC6和VS2010在处理
[C++] 前向声明(forward declaration)
1 前向声明只是一种“声明” 2 为什么前向声明在C++中是必要的 3 声明和定义之间的区别 4 前向声明能显著缩短编译链接时间 5 当
分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,
In graph theory, an Eulerian path is a path in a graph which visits every edge exactly once. Similarly, an Eulerian circ
#include <stdio.h>#include <stdlib.h>#include <time.h>int d[6];int i,n,a,b,t;int c,j;void main() { srand(