一.数组的定义

数组就是在内存中连续的相同类型的变量空间。

二.数组在内存中的存储方式

同一个数组所有的成员都是相同的数据类型,同时所有的成员在内存中的地址是连续的,数组名是一个地址的常量,代表数组中首元素的地址。

三.数组的初始化

3.1 一维数组初始化

int a[] = { , ,  };
int a[] = { };
int a[] = {,,,,,,,,,};
int a[] = {,,,,,,,,,}; // 此写法与上面的写法是等价的

注意:

在C语言中,数组未初始化就使用是极其危险的,系统会为数组中的每一个元素指定一个随机的值,因此在使用数组之前最好先初始化。

练习1:将指定数组反转

定义下列数组

int a[10] = {0,1,2,3,4,5,6,7,8,9};

将该数组中的元素进行反转(最大值在前,最小值在后)。

#include <stdio.h>

void main() {

    int a[] = {,,,,,,,,,};

    // int a[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };

    for (int i = ; i < ;i++) {

        printf("a[%d]=%d\n",i,a[i]);
} printf("------------------ 将数组反转 ------------------\n"); int min = ; // 记录当前数组的最小下标
int max = ; // 记录当前数组的最大下标 while (min < max) {
int tmp = a[min]; // 记录当前较小下标的值
a[min] = a[max]; // 将较大下标值赋值给较小下标的值
a[max] = tmp; // 将较小下标的值赋值给较大下标的值
min++;
max--;
} for (int i = ; i < ; i++) {
printf("a[%d]=%d\n",i,a[i]);
} system("pause"); }

运行结果:

 练习2:遍历数组

上面的遍历方式虽然可以使用,但是相对死板,假如数组a变为了:

int a[] = {,,,,,,,,,9,10,11,12};

则for循环中i的值也应做相应的修改。推荐写法:

void main() {

    int a[] = { , , , , , , , , , 9,10,11 };

    for (int i = ; i < sizeof(a) / sizeof(int); i++) { // int 类型占4个字节,sizeof(a)一共占40个字节,求得一共有10个元素
printf("a[%d]=%d\n",i,a[i]);
} system("pause");
}

可以利用sizeof来妥善解决上面的问题。

练习3:求一个数组中的最大值和最小值的下标

已知一个数组为

int a[] = {,,,,,,,,,,,,};

求其最大值和最小值的下标

void main() {

    // 找出该数组中最大值和最小值元素的下标
int a[] = {,,,,,,,,,,,,};
int min = a[]; // 最小值
int max = a[]; // 最大值
int min_loc = ; // 最小值下标
int max_loc = ; // 最大值下标 for (int i = ; i < sizeof(a) / sizeof(int); i++) {
if (a[i] > max) {
max = a[i];
max_loc = i;
} if (a[i] < min) {
min = a[i];
min_loc = i;
}
} printf("最大值:%d,最小值:%d\n",max,min);
printf("最大值的下标为:%d,最小值的下标为%d\n",max_loc,min_loc); system("pause"); }

练习4:查找数组中大于平均值的元素

已知一个数组为:

int a[] = { , , , , , , , , , , , ,};

查找该数组中大于平均值的元素

void main() {

    /* 查找数组中大于平均值的元素 */
int a[] = { , , , , , , , , , , , ,}; int num = sizeof(a) / sizeof(int); // 计算当前元素个数
int total = ; // 计算当前元素总和
for (int i = ; i < num; i++) {
total += a[i];
}
int avg = total / num; // 计算当前数组平均值
for (int i = ; i < num; i++) {
if (a[i] > avg) {
printf("%d\n",a[i]);
}
}
system("pause"); }

执行结果:

四.二维数组的定义及初始化

// 二维数组的定义
int a[][] = { {,,,}, {,,,}, {,,,} };
// int a[3][4] = { {1,2,3,4}, {5,6,7,8} }; // 正确,只初始化前两个维度
// int a[][4] = { { 1, 2, 3, 4 }, {5,6,7,8} }; 正确
// int a[2][] = { { 1, 2, 3, 4 }, {5,6,7,8} }; 这种写法是不对的
// int a[][] = { { 1, 2, 3, 4 }, { 5, 6, 7, 8 } }; 这种写法是不对的

练习1:遍历二维数组

void main() {

    // 二维数组的定义
int a[][] = { {,,,}, {,,,}, {,,,} };
// int a[3][4] = { {1,2,3,4}, {5,6,7,8} }; // 正确,只初始化前两个维度
// int a[][4] = { { 1, 2, 3, 4 }, {5,6,7,8} }; 正确
// int a[2][] = { { 1, 2, 3, 4 }, {5,6,7,8} }; 这种写法是不对的
// int a[][] = { { 1, 2, 3, 4 }, { 5, 6, 7, 8 } }; 这种写法是不对的 // 遍历当前二维数组
int num_1 = sizeof(a) / sizeof(a[]); // 一维数组元素个数
int num_2 = sizeof(a[]) / sizeof(a[][]); // 二维数组元素个数 for (int i = ; i < num_1; i++) { for (int j = ; j < num_2; j++) {
printf("a[%d][%d]=%d\t",i,j,a[i][j]);
}
printf("\n");
} system("pause");
}

执行结果:

C语言基础(10)-数组的更多相关文章

  1. R语言基础:数组&列表&向量&矩阵&因子&数据框

    R语言基础:数组和列表 数组(array) 一维数据是向量,二维数据是矩阵,数组是向量和矩阵的直接推广,是由三维或三维以上的数据构成的. 数组函数是array(),语法是:array(dadta, d ...

  2. Go语言基础之数组

    Go语言基础之数组 本文主要介绍数组(array)及它的基本使用. Array(数组) 数组是同一种数据类型元素的集合. 在Go语言中,数组从声明时就确定,使用时可以修改数组成员,但是数组大小不可变化 ...

  3. GO学习-(8) Go语言基础之数组

    Go语言基础之数组 Array(数组) 数组是同一种数据类型元素的集合. 在Go语言中,数组从声明时就确定,使用时可以修改数组成员,但是数组大小不可变化. 基本语法: // 定义一个长度为3元素类型为 ...

  4. Java之--Java语言基础组成—数组

    Java语言基础组成-数组 Java语言由8个模块构成,分别为:关键字.标识符(包名.类名.接口名.常量名.变量名等).注释.常量和变量.运算符.语句.函数.数组. 本片主要介绍Java中的数组,数组 ...

  5. 第二十四节:Java语言基础-讲解数组的综合应用

    数组的综合应用 // 打印数组 public static void printArray(int[] arr) { for(int x=0;x<arr.length;x++) { if(x!= ...

  6. C语言基础知识-数组和字符串

    C语言基础知识-数组和字符串 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数组概述 在程序设计中,为了方便处理数据把具有相同类型的若干变量按有序形式组织起来的方式我们称为数组 ...

  7. go语言基础之数组比较和赋值

    1.go语音基础之数组比较和赋值 示例: package main //必须有个main包 import "fmt" func main() { //支持比较,只支持 == 或 ! ...

  8. js脚本语言基础和数组

    js和PHP中,字符串赋值:要使用"双引号"或"单引号"引起来:例如:var c="你好"不同类型进行数学运算,要转换,类型转换:强制转换p ...

  9. C语言基础 (10) 变量作用域,生命周期 内存结构

    01 课程回顾 1.指针数组 注意: 对于数组来说,在使用sizeof的时候a和&a[0]是不一样的, 虽然以%x打印出来他们都是地址 2.值传递 int a; fun(a); int *** ...

随机推荐

  1. zabbix 3.0.3 (nginx)安装过程中的问题排错记录

    特殊注明:安装zabbix 2.4.8和2.4.6遇到2个问题,如下:找了很多解决办法,实在无解,只能换版本,尝试换(2.2.2正常 | 3.0.3正常)都正常,最后决定换3.0.3 1.Error ...

  2. 4-3 管理及IO重定向

    1. 系统设定默认输出设备:标准输出(STDOUT,1) 系统设定默认输入设备:标准输入(STDIN,0) 系统设定默认错误设备:标准错误(STDERR,2) 2. 标准输入:键盘 标准输出和错误输出 ...

  3. linux基础快速掌握课件

    分享一个很好的linux课件,可以快速掌握linux的基础.猛击下面的链接地址打开 http://pan.baidu.com/s/14oa9w

  4. uva 1599 ideal path(好题)——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGYAAAODCAYAAAD+ZwdMAAAgAElEQVR4nOy9L8/0ypH/Pa8givGiyC

  5. java基础学习03(java基础程序设计)

    java基础程序设计 一.完成的目标 1. 掌握java中的数据类型划分 2. 8种基本数据类型的使用及数据类型转换 3. 位运算.运算符.表达式 4. 判断.循环语句的使用 5. break和con ...

  6. UNITY自带的PACKAGE的UTILITY 里面有一个自带的FPS COUNTER

    UNITY自带的PACKAGE的UTILITY 里面有一个自带的FPS COUNTER 可用,但是脚本是保密的?

  7. Laravel与Repository Pattern(仓库模式)

    为什么要学习Repository Pattern(仓库模式) Repository 模式主要思想是建立一个数据操作代理层,把controller里的数据操作剥离出来,这样做有几个好处: 把数据处理逻辑 ...

  8. [LeetCode] Minimum Path Sum 最小路径和

    Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which ...

  9. 系统级性能分析工具perf的介绍与使用

    测试环境:Ubuntu16.04(在VMWare虚拟机使用perf top存在无法显示问题) Kernel:3.13.0-32 系统级性能优化通常包括两个阶段:性能剖析(performance pro ...

  10. python入门

    输出用print 注释用# rang() >>> range(1,5) #代表从1到5(不包含5) [1, 2, 3, 4] >>> range(1,5,2) #代 ...