我是靠谱客的博主 谨慎路灯,最近开发中收集的这篇文章主要介绍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数组元素的个数一、非参数数组二、参数数组所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部