2016 - 2024

感恩一路有你

c语言数组怎么用 为什么我觉得C语言中二维数组没用,明明两个一维数组就能解决,为什么要有二维数组存在?

浏览量:1710 时间:2021-03-15 20:57:46 作者:admin

为什么我觉得C语言中二维数组没用,明明两个一维数组就能解决,为什么要有二维数组存在?

从底层实现来看,无论是一维数组、二维数组还是多维数组,都是以一维方式排列在内存中。用一维阵列模拟多维阵列。从这一点出发,一维阵列可以解决多维阵列的问题。常用的模拟方法:

将二维数组a[M][n]表示为一维数组a[M*n

]用[y*nx]代替[y][x

]注意这里用一维数组代替二维数组

从代码清晰易读的角度来看,二维数组和多维数组是不同的有意义。有很多数据可以用二维数组或多维数组来表示。如果数据以适当的方式表示,算法将简洁明了。典型数据适合二维数组表示,如平面图形、矩阵。采用二维数组,程序清晰易读;采用一维数组,可读性要低得多。

与汇编语言相比,C提供了一些数据抽象,如数组、结构和联合。事实上,没有这些抽象,程序仍然可以被编程。但C语言的优点是具有高度的抽象性,非常适合于系统级程序的开发和维护。如果您认为C语言提供的抽象级别太高,那么汇编可能更适合您的项目。如果您认为C语言提供的抽象级别太低,那么有很多选择。从C、java到各种新语言,您可以尝试替换它们。

为什么c 中数组不能直接拷贝给另一数组?

如果您必须是直接的,只需使用指针交换。例如:将LG数组复制到CHS数组:

long LG[20];

byte CHS[200];

CHS=(char*)&lg[0];

这是直接的。记住,一定要用指针。

其次,可以使用memcpy函数来解决问题。

函数原型为void*memcpy(void*目的地,void*源,无符号n)。该函数将源内存地址开头的几个字节复制到目标内存地址,即从源内存地址复制n个字节到目标内存地址。

希望对您有所帮助。

c语言数组怎么用 c语言程序100例 c语言一维数组典型例题

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。