C语言中计算数组长度的技巧

简介: C语言中计算数组长度的技巧

C语言中计算数组长度的技巧

1、手动提前计算好

使用数组之前提前计算好使用的长度。

例如:我寄存器中只有三个参数,那么仅仅需要三个参数就行了,那么可以直接初始化三个就行

int ints[3]={1,2,3};

使用到的时候怎么办呢?

for(int i = 0; i < 3; i++)
  {
    printf("第%d值是:%d\n",i,ints[i]);
  }
  • 如果此时有成千上万个参数呢?
  • 如果你使用的时候,少数了一个呢?
  • 可都是致命的伤害,成吨的伤害呢!

2、使用宏提前定义好

这样做的目的也是为了以后好维护。也达到了,一处修改,处处修改的目的。

#include <stdio.h>
#define N 3
int main()
{
   int ints[N]={1,2,3};
  for(int i = 0; i < N; i++)
  {
    printf("第%d值是:%d\n",i,ints[i]);
  }
        return 0;
}
  • 如果我使用的参数没有限制呢?

3、如果参数没有限制怎么创建数组?

如何创建数组:

int ints[]={1,2,3,5,1,2,3,5,6,7,1,2,3,4,5,2123};

如何使用呢?

(1)自己数,有多少算多少

累死了,也不一定能数对。

for(int i = 0; i < 15; i++)
  {
    printf("第%d值是:%d\n",i,ints[i]);
  }

(2)使用宏来做一个通用的计算方式

zhenghui@zhlinux:~/codeProject/数组$ cat arr1.c 
#include <stdio.h>
#define ARRAY_SIZE(array) ((int) (sizeof(array) / sizeof(array[0])) )
int main()
{
        int ints[]={1,2,3,5,1,2,3,5,6,7,1,2,3,4,5,2123};
  for(int i = 0; i < ARRAY_SIZE(ints); i++)
  {
    printf("第%d值是:%d\n",i,ints[i]);
  }
        return 0;
}
zhenghui@zhlinux:~/codeProject/数组$ 
zhenghui@zhlinux:~/codeProject/数组$ gcc arr1.c 
zhenghui@zhlinux:~/codeProject/数组$ 
zhenghui@zhlinux:~/codeProject/数组$ ./a.out 
第0值是:1
第1值是:2
第2值是:3
第3值是:5
第4值是:1
第5值是:2
第6值是:3
第7值是:5
第8值是:6
第9值是:7
第10值是:1
第11值是:2
第12值是:3
第13值是:4
第14值是:5
第15值是:2123
zhenghui@zhlinux:~/codeProject/数组$
目录
相关文章
|
1月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
101 6
|
1月前
|
存储 算法 安全
C 语言中的位运算:挖掘底层计算的高效力量
位运算是C语言中直接操作二进制位的一种技术,能高效处理底层数据,广泛应用于优化算法、硬件编程等领域,是掌握C语言高级特性的关键之一。
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
73 5
|
2月前
|
存储 算法 C语言
C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项
本文深入探讨了C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项,并通过案例分析展示了实际应用,旨在帮助读者提高编程效率和代码质量。
121 4
|
2月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
2月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
2月前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。
|
2月前
|
存储 人工智能 算法
数据结构实验之C 语言的函数数组指针结构体知识
本实验旨在复习C语言中的函数、数组、指针、结构体与共用体等核心概念,并通过具体编程任务加深理解。任务包括输出100以内所有素数、逆序排列一维数组、查找二维数组中的鞍点、利用指针输出二维数组元素,以及使用结构体和共用体处理教师与学生信息。每个任务不仅强化了基本语法的应用,还涉及到了算法逻辑的设计与优化。实验结果显示,学生能够有效掌握并运用这些知识完成指定任务。
61 4
|
3月前
|
存储 编译器 C语言
【c语言】数组
本文介绍了数组的基本概念及一维和二维数组的创建、初始化、使用方法及其在内存中的存储形式。一维数组通过下标访问元素,支持初始化和动态输入输出。二维数组则通过行和列的下标访问元素,同样支持初始化和动态输入输出。此外,还简要介绍了C99标准中的变长数组,允许在运行时根据变量创建数组,但不能初始化。
65 6
|
3月前
|
存储 算法 C语言
C语言:什么是指针数组,它有什么用
指针数组是C语言中一种特殊的数据结构,每个元素都是一个指针。它用于存储多个内存地址,方便对多个变量或数组进行操作,常用于字符串处理、动态内存分配等场景。