我是靠谱客的博主 谨慎路灯,这篇文章主要介绍C/C++获取int数组元素的个数一、非参数数组二、参数数组,现在分享给大家,希望可以做个参考。

文章目录

  • 一、非参数数组
  • 二、参数数组
    • 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数组元素内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部