数组(更新...)

来源:互联网 发布:证大淘宝贷 编辑:程序博客网 时间:2024/05/29 11:57

在学习语言时,我们都会遇到数组.大学期间学过C,C++,Java,C#.这些语言中都学了数组,那时候用的不多,概念比较模糊,现在又学了php,里面也有数组,就打算写一篇笔记总结下不同语言的数组之间的异同.
首先看下C是怎么定义数组的:

C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。数组的声明并不是声明一个个单独的变量,比如 number0、number1、…、number99,而是声明一个数组变量,比如 numbers,然后使用 numbers[0]、numbers[1]、…、numbers[99] 来代表一个个单独的变量。数组中的特定元素可以通过索引访问。所有的数组都是由连续的内存位置组成。最低的地址对应第一个元素,最高的地址对应最后一个元素。

声明数组(需要指定元素的类型和元素的数量):
type arrayName [ arraySize ];
这叫做一维数组。arraySize 必须是一个大于零的整数常量,type 可以是任意有效的 C 数据类型。例如,要声明一个类型为 double 的包含 10 个元素的数组 balance(可以容纳 10 个类型为 double 的数字。),声明语句如下:
double balance[10];

在 C 中,可以逐个初始化数组,也可以使用一个初始化语句

double balance[5] = {1000.0, 2.0, 3.4, 7.0, 50.0};

如何访问数组?
double salary = balance[9];

上面的语句将把数组中第 10 个元素的值赋给 salary 变量。下面的实例使用了上述的三个概念,即,声明数组、数组赋值、访问数组:

#include <stdio.h>int main (){   int n[ 10 ]; /* n 是一个包含 10 个整数的数组 */   int i,j;   /* 初始化数组元素 */            for ( i = 0; i < 10; i++ )   {      n[ i ] = i + 100; /* 设置元素 i 为 i + 100 */   }   /* 输出数组中每个元素的值 */   for (j = 0; j < 10; j++ )   {      printf("Element[%d] = %d\n", j, n[j] );   }   return 0;}

编译结果

Element[0] = 100
Element[1] = 101
Element[2] = 102
Element[3] = 103
Element[4] = 104
Element[5] = 105
Element[6] = 106
Element[7] = 107
Element[8] = 108
Element[9] = 109

C 语言支持多维数组(二维数组)。多维数组声明的一般形式如下:
type name[size1][size2]...[sizeN];
一个二维数组,在本质上,是一个一维数组的列表。声明一个 x 行 y 列的二维整型数组,形式如下:
type arrayName [ x ][ y ];
type 可以是任意有效的 C 数据类型,arrayName 是一个有效的 C 标识符。一个二维数组可以被认为是一个带有 x 行和 y 列的表格.
数组中的每个元素是使用形式为 a[ i , j ] 的元素名称来标识的,其中 a 是数组名称,i 和 j 是唯一标识 a 中每个元素的下标。
初始化二维数组
多维数组可以通过在括号内为每行指定值来进行初始化。下面是一个带有 3 行 4 列的数组

int a[3][4] = {   {0, 1, 2, 3} ,   /*  初始化索引号为 0 的行 */ {4, 5, 6, 7} ,   /*  初始化索引号为 1 的行 */ {8, 9, 10, 11}   /*  初始化索引号为 2 的行 */};

内部嵌套的括号是可选的,下面的初始化与上面是等同的:
int a[3][4] = {0,1,2,3,4,5,6,7,8,9,10,11};

访问二维数组元素
二维数组中的元素是通过使用下标(即数组的行索引和列索引)来访问的。例如:int val = a[2][3];
上面的语句将获取数组中第 3 行第 4 个元素。下面使用嵌套循环来处理二维数组:

#include <stdio.h>int main (){   /* 一个带有 5 行 2 列的数组 */   int a[5][2] = { {0,0}, {1,2}, {2,4}, {3,6},{4,8}};   int i, j;   /* 输出数组中每个元素的值 */   for ( i = 0; i < 5; i++ )   {      for ( j = 0; j < 2; j++ )      {         printf("a[%d][%d] = %d\n", i,j, a[i][j] );      }   }   return 0;}

结果:

a[0][0]: 0a[0][1]: 0a[1][0]: 1a[1][1]: 2a[2][0]: 2a[2][1]: 4a[3][0]: 3a[3][1]: 6a[4][0]: 4a[4][1]: 8

C 传递数组给函数

通过指定不带索引的数组名称来给函数传递一个指向数组的指针。

三种方式来声明函数形式参数

  • 形参是一个指针
void myFunction(int *param){...}
  • 形参是一个已定义大小的数组
    “`
    void myFunction(int param[10])
    {

    }
 形参是一个未定义大小的数组

void myFunction(int param[ ])
{

}

**C 从函数返回数组**> C 语言不允许返回一个完整的数组作为函数的参数。但是,可以通过指定不带索引的数组名来返回一个指向数组的指针。再来学习本章的内容。如果想要从函数返回一个一维数组,必须声明一个返回指针的函数.> 另外,C 不支持在函数外返回局部变量的地址,除非定义局部变量为 static 变量。`#include <stdio.h>`

/* 要生成和返回随机数的函数 */
int * getRandom( )
{
static int r[10];
int i;

/* 设置种子 */
srand( (unsigned)time( NULL ) );
for ( i = 0; i < 10; ++i)
{
r[i] = rand();
printf( “r[%d] = %d\n”, i, r[i]);

}

return r;
}

/* 要调用上面定义函数的主函数 */
int main ()
{
/* 一个指向整数的指针 */
int *p;
int i;

p = getRandom();
for ( i = 0; i < 10; i++ )
{
printf( “(p + %d) : %d\n”, i, (p + i));
}

return 0;
}

结果:

r[0] = 313959809
r[1] = 1759055877
r[2] = 1113101911
r[3] = 2133832223
r[4] = 2073354073
r[5] = 167288147
r[6] = 1827471542
r[7] = 834791014
r[8] = 1901409888
r[9] = 1990469526
*(p + 0) : 313959809
*(p + 1) : 1759055877
*(p + 2) : 1113101911
*(p + 3) : 2133832223
*(p + 4) : 2073354073
*(p + 5) : 167288147
*(p + 6) : 1827471542
*(p + 7) : 834791014
*(p + 8) : 1901409888
*(p + 9) : 1990469526
“`

0 0
原创粉丝点击