数组:只能存放一种数据类型,比如int类型的数组、float类型的数组,里面存放的数据称为“元素”。

数组的定义:

首先声明数组的类型,然后声明数组元素的个数,也就是定义需要多少存储空间。

数组格式与初始化

格式:

元素类型 数组名[元素个数];

比如:

int[3];

数组元素有顺序之分,每个元素都有一个唯一的下标(索引),而且都是从0开始。

数组中第i个元素的访问方式:

a[i]

数组元素的初始化:

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

[ ]里面的个数必须是一个固定值,可以是常量(比如6、8)、常量表达式(比如3 4、5*7)。绝对不能使用变量或者变量表达式来表示元素个数,大多数情况下不要省略元素个数,当数组作为函数的形参和数组初始化时除外。

C语言中编译器是不会对数组下标越界进行检查的,所以自己访问数组元素时要注意。

一维数组

数组的内存细节分析

#include
int main()
{char cs[5] = {'a','A','D','e','f'};      printf("%p\n",cs);  // 数组名就代表数组的地址    for (int i = 0; i<5; i  )    {     printf("cs[%d]的地址是:%p\n",i ,&cs[i]);    }    return 0;
}

上面代码中,地址分配分析如下:

一维数组的元素作为函数实参,与同类型的简单变量作为实参一样,是单向的值传递,即数组元素的值传给形参,从而形参是改变不影响实参。

数组名代表着整个数组的地址,如果一维数组的名字作为函数实参,传递的是整个数组,即形参数组和实参数组完全相同,是存放在同一存储空间的同一个数组。这样形参数组修改时,实参数组也同时被修改了。形参数组的元素个数可以省略。

// b是test函数的形参(形式参数)
void test(int b) {   b = 9;
}
int main()
{  int a[3];    a[0] = 10;      printf("函数调用前的a[0]:%d\n", a[0]);    test(a[0]); // a[0]是test函数的实参(实际参数)    printf("函数调用后的a[0]:%d", a[0]);    return 0;
}
#include
//数组作为函数参数,可以省略元素个数
//数组作为函数参数,传递是整个数组的地址,修改了函数形参数组元素的值,会影响到外面的实参数组
void change(int array[])
{  printf("array ==%p\n",array);     array[0] = 100;
}
int main()
{  int ages[6] = {10,11,13,15,11,18};    printf("array ==%p\n",ages);    change(ages);       printf("%d\n",ages[0]);    return 0;
}

输出结果为:

array ==0x7fff5be26c00
array ==0x7fff5be26c00
100

数组的小练习,找最大值:

/*
设计一个函数,找出整型数组元素的最大值
*/ #includeint maxOfArray(int array[], int length)
{  // 数组当做函数参数传递时,会当做指针变量来使用,指针变量在64bit编译器环境下,占据8个字节     //int size = sizeof(array);    //printf("array=%d\n", size);     //sizeof(array);     // 1.定义一个变量存储最大值(默认就是首元素)    int max = array[0];     // 2.遍历所有元素,找出最大值    for (int i = 1; i {      // 如果当前元素大于max,就用当前元素覆盖max        if (array[i] > max)        {         max = array[i];        }    }     return max;
} int main()
{  int ages[] = {11, 90, 67, 150, 78, 60, 70, 89, 100};     int ages2[] = {11, 90, 67, 150, 78, 60, 70, 89, 100};     //int size = sizeof(ages);     //printf("ages=%d\n", size);    int max = maxOfArray(ages, sizeof(ages)/sizeof(int));     printf("%d\n", max);    return 0;
}

二维数组

一个数组能表示一个班人的年龄,如果想表示很多班呢?

什么是二维数组?int ages[3][10]; 三个班,每个班10个人,相当于3行10列,相当于装着3个一维数组。

二维数组是一个特殊的一维数组:它的元素是一维数组。例如int a[2][3]可以看作由一维数组a[0]和一维数组a[1]组成,这两个一维数组都包含了3个int类型的元素。

定义形式:

类型  数组名[ 行数] [列数]
int  a[2][3];   //2行3列的二维数组

二维数组的存放顺序是按行存放的,先存放第一行的元素,再存放第2行的元素。例如int a[2][3]的存放顺序是:

a[0][0] → a[0][1] → a[0][2] → a[1][0] → a[1][1] → a[1][2]

二维数组的内存存储分配

注意:a[0]、a[1]也是数组,是一维数组,而且a[0]、a[1]就是数组名,因此a[0]、a[1]就代表着这个一维数组的地址。

  • 数组a的地址是ffc1,数组a[0]的地址也是ffc1,即a = a[0]

  • 元素a[0][0]的地址是ffc1,所以数组a[0]的地址和元素a[0][0]的地址相同,即a[0] = &a[0][0]

  • 最终可以得出结论:a = a[0] = &a[0][0],以此类推,可以得出a[1] = &a[1][0]

二维数组的初始化:

   int ages2[3][5]= {     {10, 11, 90, 89, 70},           {10, 11, 90, 89, 70},        {10, 11, 90, 89, 70}    };

声明:

本文于网络整理,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜。

总结C语言中的数组知识点相关推荐

  1. c语言删除数组中的最小值,C语言中删除数组中某个元素的方法

    C语言中删除数组中某个元素的方法 发布时间:2020-06-17 14:22:39 来源:亿速云 阅读:1964 作者:鸽子 C语言实现删除数组中某个元素 大家知道C语言实现删除数组中某个元素方法吗? ...

  2. c语言二维数组作用,C语言二维数组知识点介绍

    C语言二维数组知识点介绍 数组可以看作是一行连续的数据,只有一个下标,称为一维数组.在实际问题中有很多量是二维的或多维的,因此C语言允许构造多维数组.多维数组元素有多个下标,以确定它在数组中的位置.本 ...

  3. c语言中字符串数组的地址存放以及%s输出单个字符导致程序崩溃的问题

    代码 总结下c语言中字符串数组的地址存放问题 #include <iostream> using namespace std; #include<bits/stdc++.h>i ...

  4. C语言中动态数组的作用,C语言实现动态数组

    前言 在纯C语言编程中,数组的创建必须是固定的大小,因为C语言本身没有提供动态数组这种数据结构,这是一个让习惯了使用高级语言编程的人转做C开发面临的一个很头疼的问题,本篇文章就将介绍如何使用纯C语言编 ...

  5. 【示例】C语言中利用数组存放函数指针

    C语言中利用数组存放函数指针,增加函数使用的灵活性.使用时只需提供数组索引,即可调用不同函数. 预备知识: 1.指向函数的指针 一个函数在编译时被分配一个入口地址,这个地址就被称为函数的指针. 例如: ...

  6. C++与C语言中有关数组中元素排序

    C++与C语言中有关数组中元素排序 C语言中 ​ #include<stdio.h> #define n 4 int main(){ int a[n]; int i,j,temp; for ...

  7. 在c语言中引用数组元素时,其数组下标的数据类型允许是什么

    在c语言中引用数组元素时,其数组下标的数据类型允许是:整型常量或整型表达式.C语言规定只能逐个引用数组元素而不能一次引用整个数组,数据元素的表示形式为"数组名[下标]",下标可以是 ...

  8. C语言中字符数组的初始化与注意事项

    在C语言中字符数组的初始化有三种常见的方法: char a[5] = {'a','b','c','d','e'};char c[] = {'a','b','c','d','e'};char b[] = ...

  9. Java语言中的----数组

    day07  Java语言中的--数组 一.数组的概述: 什么是数组?数组是干什么用的?为啥要学数组?这些都是疑问.再你学完数组以后就知道了,数组是存储在相邻内存位置的单一数据类型的元素集合.什么是单 ...

最新文章

  1. TensorFlow指定CPU和GPU方法
  2. 洛谷 P3302 [SDOI2013]森林 主席树+启发式合并
  3. matlab与python 语言区别总结(1)_matlab与python 语言区别总结(1)
  4. docker 镜像重命名_Docker 镜像该怎么传
  5. matlab保存数据
  6. ElementUI中el-form实现表单重置以及将方法抽出为全局方法
  7. response.setHeader各种用法 .
  8. 前端为什么有的接口明明是成功回调却执行了.catch失败回调_前端进阶高薪必看-手写源码篇(高频技术点)...
  9. Eclipse 插件ibeetl
  10. js模块封装示例_AngularJS模块教程示例
  11. 在 Intellij IDEA 中 调试 angular e2e test
  12. 论EFMS模拟量部分采集电路的修改
  13. 账龄分析表excel模板_经理都头疼的财务分析表!新手会计用10套模板半时搞定,厉害...
  14. gmx一定要在linux下运行么,gmx_mmpbsa使用说明
  15. nginx上传文件大小限制
  16. 国家计算机2级考试模板,全国计算机二级考试《C++》笔试样卷
  17. go语言判断文件是否为UTF8编码
  18. 【原创】【个人向】CSP-S 2019 爆炸退役记 (已完成)
  19. Charles--使用Charles抓Https包
  20. 微信小程序提交上线时 定位接口提示未配置

热门文章

  1. JMetro版本4.8已发布
  2. Spring Reactor教程
  3. Drools可执行模型还活着
  4. java 和javafx_JavaFX 2 XYCharts和Java 7功能
  5. Hystrix简介– Hello World
  6. Java编译器API
  7. jasper 获取当前日期_入侵Jasper以获取JSP页面的对象模型
  8. Java 8中的策略模式
  9. Java线程面试的前50个问题,面向初学者和经验丰富的程序员
  10. Spring 3.1,Cloud Foundry和本地开发