C语言求数组长度的5种方法

这篇具有很好参考价值的文章主要介绍了C语言求数组长度的5种方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

c语言求数组长度length,c语言,算法,数据结构,开发语言

1,使用 sizeof 运算符

#include <stdio.h>


int main() {
    int array[] = {1, 2, 3, 4, 5};
    unsigned char length = sizeof(array) / sizeof(array[0]);


    printf("Array length: %d\n", length);


    return 0;
}

解析:sizeof(array) 返回整个数组的字节大小,sizeof(array[0]) 返回数组中一个元素的字节大小。通过相除可以得到数组的元素个数。

2,使用宏定义

#include <stdio.h>


#define ARRAY_LENGTH(arr) (sizeof(arr) / sizeof(arr[0]))


int main() {
    int array[] = {1, 2, 3, 4, 5};
    unsigned char length = ARRAY_LENGTH(array);


    printf("Array length: %d\n", length);


    return 0;
}

    解析:这里使用了宏定义,将获取数组长度的操作封装在 ARRAY_LENGTH 中,使得代码更具可读性。

3,传递数组和数组长度给函数

#include <stdio.h>


unsigned char getArrayLength(int *arr, size_t size) {
    return size;
}


int main() {
    int array[] = {1, 2, 3, 4, 5};
    unsigned char length = getArrayLength(array, sizeof(array) / sizeof(array[0]));


    printf("Array length: %d\n", length);
    
    return 0;
}

解析:函数 getArrayLength 接受一个指向整数的指针和数组的大小,然后直接返回数组的大小。

4,使用 strlen(适用于字符串数组)

#inlude <stdio.h>
#include <string.h>


int main() {
    char strArray[] = "Hello, World!";
    unsigned char length = strlen(strArray);


    printf("String Array length: %d\n", length);


    return 0;
}

解析:strlen 函数用于计算字符串的长度,适用于以 null 结尾的字符串数组。

5,使用指针

#include <stdio.h>


int main() {
    int array[] = {1, 2, 3, 4, 5};
    int *ptr = array;
    unsigned char length = sizeof(array) / sizeof(*ptr);


    printf("Array length: %d\n", length);


    return 0;
}

解析:将数组的首地址赋给指针,然后通过指针进行操作。这里同样使用了 sizeof 方法。

==========

往期回顾:

寄存器开发,HAL开发和LL开发的区别和参考代码

对应届大学生找工作的建议

KEIL 开发技巧

把一个MOS管制作成开关电路

==========

c语言求数组长度length,c语言,算法,数据结构,开发语言

c语言求数组长度length,c语言,算法,数据结构,开发语言文章来源地址https://www.toymoban.com/news/detail-771452.html

到了这里,关于C语言求数组长度的5种方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构与算法教程,数据结构C语言版教程!(第五部分、数组和广义表详解)五

    数组和广义表,都用于存储逻辑关系为“一对一”的数据。 数组存储结构,99% 的编程语言都包含的存储结构,用于存储不可再分的单一数据;而广义表不同,它还可以存储子广义表。 本章重点从矩阵的角度讨论二维数组的存储,同时讲解广义表的存储结构以及有关其广度和

    2024年01月23日
    浏览(9)
  • JAVA测试报错idsException : Index 0 out of bounds for length 0:意为数组索引越界异常,索引0超出长度0的界限。怎么解决呢?

    报错idsException : Index 0 out of bounds for length 0:意为数组索引越界异常,索引0超出长度0的界限 这段代码本身并没有明显的数组索引越界异常,因为它对line数组中的第一个和第二个元素分别进行了访问,而且在访问之前还没有做数组长度的检查。但是,如果line数组的长度小于

    2024年02月13日
    浏览(6)
  • Hadoop 请求数据长度 Requested Data length 超过配置的最大值

    Spark 任务速度变慢,也不失败。 DataNode 内存足够 CPU 负载不高 GC 时间也不长。 查看 DataNode 日志,发现有些日志出现很多 Netty RPC 超时。超时的 destination 是一个 NameNode 节点,然后查看 NameNode 节点的日志,报错如下: 查找对应 Hadopo 源码 源码 org.apache.hadoop.ipc.Server.Connection#c

    2024年02月08日
    浏览(13)
  • C语言数据结构一:动态数组

    先说一个概念:数组是一段 连续 的内存空间。存储相同的数据类型。 数组的两个关键点: 连续内存; 相同类型。 首先连续内存:所以为了找到动态数组我们必须找到一个 首元素 地址。(内存 首地址 。) 如果不知道首地址,那无法找到并操作内存空间。 知道首地址了,

    2024年02月06日
    浏览(12)
  • 数据结构与算法 | 数组(Array)

    数组(Array)应该是最基础的数据结构之一,它由相同类型的元素组成的集合,并按照一定的顺序存储在内存中。每个元素都有一个唯一的索引,可以用于访问该元素。 数组索引(Index): 数组中的每个元素都有一个唯一的整数索引,从0开始计数。索引用于访问数组中的元素

    2024年02月08日
    浏览(12)
  • 数据结构与算法(一): 稀疏数组

    在五子棋游戏或类似的游戏中,我们可以把整个棋盘想象成是一个有规律的二维数组,其值由0、1、2三个数字组成,0代表空白区域,1代表白子,2代表黑子。这种情况:即当一个数组中大部分元素为0或者为同一值时,存储该数组数据可以使用稀疏数组来对原始数组进行精简,

    2024年02月11日
    浏览(14)
  • 数据结构(C语言实现)——常见排序算法的基本思想及实现(快速排序的三种方法和优化及非递归实现快速排序)

    生活中几乎处处都会用到排序,比如:网购时的店铺顺序,学生成绩的排名等,今天我们就来学习数据结构中常见的几种排序算法。 排序 :所谓排序,就是使一串记录,按照其中的某个或某些的大小,递增或递减的排列起来的操作。 稳定性 :假定在待排序的记录序列

    2023年04月24日
    浏览(14)
  • JavaScript数据结构与算法整理------数组

            数组的标准定义: 一个存储元素的线性集合,元素可以通过索引来任意存取,索引通常是数字,用来计算元素之间存储位置的偏移量 ,几乎所有的编程语言都有类似的数据结构,而JavaScript的数组略有不同。         JavaScript中的数组是一种特殊的对象,用来表示偏

    2023年04月24日
    浏览(18)
  • 数据结构与算法-数组(附阿里面试题)

            给你一个文件里面包含全国人民(14亿)的年龄数据(0~180),现在要你统计每一个年龄   有多少人?          给定机器为 单台+2CPU+2G内存。不得使用现成的容器,比如map等。 (这一句可以忽略)         在以上情况下你该如何以最高效的方法来解决这个

    2024年02月13日
    浏览(12)
  • 【数据结构和算法】寻找数组的中心下标

    Java基础合集 数据结构与算法合集 设计模式合集 多线程合集 分布式合集 ES合集 其他系列文章导航 文章目录 前言 一、题目描述 二、题解 2.1 前缀和的解题模板 2.1.1 最长递增子序列长度 2.1.2 寻找数组中第 k 大的元素 2.1.3 最长公共子序列长度 2.1.4 寻找数组中第 k 小的元素 2

    2024年02月04日
    浏览(10)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包