文章目录
- 一、非参数数组
- 二、参数数组
- 1.问题
- 2.解决方法
- (1)全局变量数组
- (2)增加一个参数length
- (3)全局变量length
一、非参数数组
可以使用sizeof(a)/sizeof(a[0])
或sizeof(a)/sizeof(int)
来获取元素个数。
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13#include <iostream> using namespace std; int a[] = {1, 2, 3}; int main() { int b[] = {1, 2, 3}; cout << sizeof(a) / sizeof(int) << endl; // 3 cout << sizeof(b) / sizeof(b[0]) << endl; // 3 return 0; }
二、参数数组
1.问题
不可以使用sizeof(a)/sizeof(a[0])
或sizeof(a)/sizeof(int)
来获取元素个数。
因为sizeof(a)
中的a被认为是指针类型的字节(32位机子结果是4字节,64位机子结果是8字节),而不是数组的所占的字节。
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18/* 64位机子上 */ #include <iostream> using namespace std; void func(int a[]) { cout << sizeof(a) << endl; // 8 cout << sizeof(a) / sizeof(int) << endl; // 2 cout << sizeof(a) / sizeof(a[0]) << endl; // 2 } int main() { int a[] = {1, 2, 3}; func(a); return 0; }
2.解决方法
(1)全局变量数组
一般ACM比赛用这样。
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17#include <iostream> using namespace std; int a[] = {1, 2, 3}; void func() { cout << sizeof(a) / sizeof(int) << endl; // 3 cout << sizeof(a) / sizeof(a[0]) << endl; // 3 } int main() { func(); return 0; }
(2)增加一个参数length
一般排序算法就采用这样的形式。
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14#include <iostream> using namespace std; void func(int a[], int length) {} int main() { int a[] = {1, 2, 3}; int length = sizeof(a) / sizeof(a[0]); // int length = sizeof(a) / sizeof(int); func(a, length); return 0; }
(3)全局变量length
记得在数组的相关部分初始化全局变量length
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16#include <iostream> using namespace std; int length; void func(int a[]) {} int main() { int a[] = {1, 2, 3}; length = sizeof(a) / sizeof(a[0]); // length = sizeof(a) / sizeof(int); func(a); return 0; }
最后
以上就是谨慎路灯最近收集整理的关于C/C++获取int数组元素的个数一、非参数数组二、参数数组的全部内容,更多相关C/C++获取int数组元素内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复