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

文章目录

  • 一、非参数数组
  • 二、参数数组
    • 1.问题
    • 2.解决方法
      • (1)全局变量数组
      • (2)增加一个参数length
      • (3)全局变量length


一、非参数数组

可以使用sizeof(a)/sizeof(a[0])sizeof(a)/sizeof(int)来获取元素个数。

#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字节),而不是数组的所占的字节。

/* 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比赛用这样。

#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

一般排序算法就采用这样的形式。

#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

#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数组元素内容请搜索靠谱客的其他文章。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部