c++中怎么获取数组中元素的个数

如题所述

C++中数组可分为堆区的数组和栈区的数组,对于两种数组C++都没有函数可以直接获取数组的元素的个数。

一、堆区的数组

堆区的数组是自己申请的,比如用new申请空间:

int* arr = new int[10];

堆区的数组不能计算出包含元素个数。

二、栈区的数组

栈区的数组是系统自动分配的,如:

[cpp] view plain copy

    int arr[10] = { 1,2,3,4,5,6,7,8,9,0 };  


    栈区的数组可以通过以下两种方法得出元素的个数:

    (1)

    [cpp] view plain copy

    int arr[10] = { 1,2,3,4,5,6,7,8,9,0 };  

    auto diff = sizeof(arr)/sizeof(int);  


    (2)

    这种方法需要所用编译器支持C++11,14

    [cpp] view plain copy

    int arr[10] = { 1,2,3,4,5,6,7,8,9,0 };  

    int *pbeg = begin(arr);  

    int *pend = end(arr);  

    auto length = pend - pbeg;//数组元素个数  

温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-08-23
_countof()被楼上吃了
第2个回答  2019-07-21
C++中没有现成的获取数组元素个数的方法,只有自己写。
int count = sizeof(array) / sizeof(array[0]);

1、对于数组的查询,其实就是对数组中数据做一个遍历。最常用的方法就是通过循环对数组中的元素逐个取值,并与参考值(要查询的值)做比对,并处理结果。
下面是一个简单的对一维数组进行查询的样例。
函数功能:对输入的数组元素进行查询,打印符合查询值的元素位置,并返回查询到的元素总数。
函数名:array_query函数声明: int array_query(int *a, int n, int v);
参数介绍:
a: 输入的数组,类型为整型指针,表示整型数组。可以根据实际需要进行调整。
n:数组中现有元素的个数。
v:要查询的元素值。返回值:
整型,返回查询到的元素个数。如果出错返回-1。
2、实现代码:

int array_query(int *a, int n, int v)
{
int i,ret;

if(a == NULL || n <= 0) return -1; //出错处理
for(ret = i = 0; i < n; i ++)
{
if(a[i] == n)
{
printf("%d\n", i);//找到元素,打印下标,并累计统计值
ret ++;
}
}

return ret;//返回总数。
}