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 };
int arr[10] = { 1,2,3,4,5,6,7,8,9,0 };
auto diff = sizeof(arr)/sizeof(int);
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)
[cpp] view plain copy
(2)
这种方法需要所用编译器支持C++11,14
[cpp] view plain copy
2019-08-23
展开全部
_countof()被楼上吃了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
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;//返回总数。
}
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;//返回总数。
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询