库拉索芦荟 - 芦荟汇聚地!

c 数组

c语言中什么是数组

  数组是计算机编程语言上,对于“Array”的中文称呼。将相同数据类型的元素按一定顺序排列的集合,把有限个类型相同的变量用一个名字命名,然后用编号区分他们的变量的集合,这个名字成为数组名,编号成为下标。组成数组的各个变量成为数组的分量,也称为数组的元素,有时也称为下标变量。数组是在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式组织起来的一种形式。这些按序排列的同类数据元素的集合称为数组。 c语言数组   在C语言中, 数组属于构造数据类型。一个数组可以分解为多个数组元素,这些数组元素可以是基本数据类型或是构造类型。因此按数组元素的类型不同,数组又可分为数值数组、字符数组、指针数组、结构数组等各种类别。   关于可变长数组(VLA)的问题:原来的C标准中是不允许可变长数组出现的,但是在C++中,加入了对VLA的支持,也有不少编译器已经支持这个了,而且好像没有太多的人用这个可变长数组。   如果有过用其它语言编程的经历,那么想必会熟悉数组的概念。由于有了数组,可以用相同名字引用一系列变量,并用数字(索引)来识别它们。在许多场合,使用数组可以缩短和简化程序,因为可以利用索引值设计一个循环,高效处理多种情况。数组有上界和下界,数组的元素在上下界内是连续的。因为 Visual Basic对每一个索引值都分配空间,所以不要不切实际声明一个太大的数组。   此处数组是程序中声明的变量数组。它们不同于控件数组,控件数组是在设计时通过设置控件的 Index 属性规定的。变量数组总是连续的;与控件数组不同的是,不能从一个数组的中部加载或卸载数组元素。   一个数组中的所有元素具有相同的数据类型(在C、C++、Java、pascal中都这样。但也并非所有涉及数组的地方都这样,比如在Visual Foxpro中的数组就并没这样的要求)。当然,当数据类型为 Variant 时,各个元素能够包含不同种类的数据(对象、字符串、数值等等)。可以声明任何基本数据类型的数组,包括用户自定义类型和对象变量。   如果要用户输入的是一个数组,一般是用一个循环,但是在输入前也需要固定数组的大小。   compact跟变长数组没有太大的关系,也应该用不到变长数组。因为一般的传数组到函数中就是传数组的地址和元素的个数的,那只是一个提示,不是要求。   原型可以这样写(假设数组的元素是type):   int compact(type *Array,int Count)   数组类型说明 在C语言中使用数组必须先进行类型说明。   数组说明的一般形式为:类型说明符 数组名 [常量表达式],……; 其中,类型说明符是任一种基本数据类型或构造数据类型。数组名是用户定义的数组标识符。方括号中的常量表达式表示数据元素的个数,也称为数组的长度。

array在c语言中的意思是什么?

array就是数组的意思。int array[n];表示定义了一个可包含n个元素、名为array的整型数组。array不是C语言中的关键字,只是编程人员自定义的一个变量或数组等,通常用来定义数组,是数组的英文。举例说明如下:int array; // 定义一个int型变量,变量名为array。int array[5]; // 定义一个int型数组,数组名为array,含5个元素。c语言中array是编程人员定义的一个变或数组等,通常用来定义数组,是数组的英文。C语言是一门面向过程、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言以及不需要任何运行环境支持便能运行的高效率程序设计语言。尽管C语言提供了许多低级处理的功能,但仍然保持着跨平台的特性,以一个标准规格写出的C语言程序可在包括一些类似嵌入式处理器以及超级计算机等作业平台的许多计算机平台上进行编译。

C语言中的数组什么意思?

所谓数组,是有序的元素序列。数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按无序的形式组织起来的一种形式。这些无序排列的同类数据元素的集合称为数组。比如油烟机的风扇转速会和工作的模式之间有一定的关系,那么我们就可以把它的工作模式和一维数组的下标对应起来,我们将具体的转速放在数组中,这样的话就非常方便我们在日后查询。再比如说家中的冷暖灯光控制这方面,色温灯里会有两个灯珠,分别对应的是冷光和暖光,选择不同的模式灯光的颜色就不同,我们就可以将这两种灯光的亮度pwm值事先放在二维数组中,以便调用调光。在程序中合理地使用数组,会使程序的结构比较整齐,而且可以把较为复杂的运算,转化成简单的数组来表示。扩展资料:一、使用规则:1、可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只给前面部分元素赋值。2、只能给元素逐个赋值,不能给数组整体赋值。(请注意:在C、C#语言中是这样,但并非在所有涉及数组的地方都这样,数据库是从1开始。)3、若不给可初始化的数组赋初值,则全部元素均为0值。4、假如给全部元素赋值,则在数组说明中, 可以不给出数组元素的个数。动态赋值可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。二、表示方法:数组元素是组成数组的基本单元。数组元素也是一种变量, 其标识方法为数组名后跟一个下标。下标表示了元素在数组中的顺序号。数组元素的一般形式为:数组名[下标] 其中的下标只能为整型常量或整型表达式。如为小数时,C编译将自动取整。例如,a[5],a[i+j],a[i++]都是合法的数组元素。数组元素通常也称为下标变量。必须先定义数组, 才能使用下标变量。在C语言中只能逐个地使用下标变量, 而不能一次引用整个数组。参考资料:百度百科-数组

关于c语言数组的一些疑惑?

数组元素不能做形参,这个论述是正确的。
我们都知道,单个元素可以做形参,数组也可以做形参。但是,二者有本质上的区别。
单个元素做形参,是建立一个变量副本,程序运行时,实参把值传给副本,就没有实参的什么事了,后面对副本的赋值、改写,都不会影响实参。
而数组做形参时,只是把实参的首地址传给形参,后面对形参的元素的赋值和改写,直接对实参的数组元素进行了赋值和改写。
在C语言中,array[10]有两种含义:
①它指含有10个元素的数组array,如:
int array[10];
②它指数组array的第10号元素,如:
array[10] =5;
因此,对于使用数组array[10](这里,你要把array[10]理解成含有10个元素的数组array,而不能理解成第10号元素)做形参,只写array[]即可(只写一个空的中括号)。
但是,数组做形参时,C语言支持中括号里面写入数字,如array[0]、array[1]或array[10]等,但它们都是一样的,作用与写成array[]完全相同。
就是说,数组做形参时,你可以无视中括号内的数字(程序运行时,也不管中括号内的数字)。
所以,定义函数语句:
float average( float array[10])
与写成:
float average(float array[])
完全相同。
补充一点,数组形参的中括号内写上一个10,也有一个好处,它提醒编程人员这里需要一个含有10个元素的数组!但千万不要理解成数组的第10号元素做形参。
OK?


c语言数组定义的几种方式

数组的定义数组就是指用于存储同一类型数据的集合,一个数组实际上就是一连串的变量,数组按照使用可以分为一维数组、二维数组、多维数组数组定义的方式数组定义的方式有四种形式,分别是:(1)类型名[] 数组名;(2)类型名[] 数组名 = { 初始值列表 };(3)类型名[] 数组名 = new 类型名[ 数组大小 ];(4)类型名[] 数组名 = new 类型名[ 数组大小 ] { 初始值列表 };数据类型:指的是数组元素的数据类型,常见的有整形、浮点型、与字符型等数组名:是用来统一这组相同数据类型元素的名称,其命名规则和变量的相同


c语言中能不能定义函数数组

函数不可以定义为数组,可以用函数指针来操作。1.函数指针的数组定义方法:返回值类型( * 指针变量名[Number]) (形参列表)。例如:double add(double a,double b){}double sub(double a,double b){}double mul(double a,double b){}double div1(double a,double b){}double (*oper_func[])(double, double) = {add,sub,mul,div1};//函数指针的数组定义。2.函数指针是指向函数的指针变量。 因而“函数指针”本身首先应是指针变量,只不过该指针变量指向函数。这正如用指针变量可指向整型变量、字符型、数组一样,这里是指向函数。C在编译时,每一个函数都有一个入口地址,该入口地址就是函数指针所指向的地址。有了指向函数的指针变量后,可用该指针变量调用函数。扩展资料:指针函数和函数指针的区别:这两个概念都是简称,指针函数是指返回值是指针的函数,即本质是一个函数。我们知道函数都有返回类型(如果不返回值,则为无值型),只不过指针函数返回类型是某一类型的指针。其定义格式如下所示:返回类型标识符*函数名称。返回类型可以是任何基本类型和复合类型。返回指针的函数的用途十分广泛。事实上,每一个函数,即使它不带有返回某种类型的指针,它本身都有一个入口地址,该地址相当于一个指针。比如函数返回一个整型值,实际上也相当于返回一个指针变量的值,不过这时的变量是函数本身而已,而整个函数相当于一个“变量”。参考资料:百度百科 - 函数指针

大家都在看