C语言从基础到进阶全面讲解数组

目录
  • 1.基础知识
  • 2.数组的分类
    • 2.1按元素类型分类
    • 2.2按维数分类
  • 3.数组定义和初始化
    • 3.1 一维数组
    • 3.2 二维数组
  • 4.数组元素的引用方法
  • 5.字符数组的定义

1.基础知识

  • C语言中使用数组表示多个连续的同类型的存储位置
  • 使用数组表示多个连续存储位置的时候只需要一个名字,这个名字代表所有这些存储位置的整体
  • 每一个存储位置有一个自己的编号,最前边的存储位置的编号是0,向后依次递增,最后一个存储位置的编号是个数减一,这个编号叫做下标
  • 决不可以使用超过范围的下标
  • 使用名称和下标就可以表示这组存储位置中的某一个

2.数组的分类

2.1按元素类型分类

  • 字符数组:若干个字符变量的集合
  • 短整型数组
  • 整型数组
  • 长整型数组
  • 浮点型数组
  • 指针数组
  • 结构体数组

2.2按维数分类

  • 一维数组
  • 二维数组
  • 多维数组

3.数组定义和初始化

3.1 一维数组

格式: 数据类型 数组名[数组元素的个数];

数组名和元素个数中间没有空格

int a[10];定义了一个名为a的数组,每个元素都是int类型,一共有10个元素 数组元素的个数在定义的时候也可以不写,但是需要初始化,如下例的b[ ]

#include<stdio.h>
int main(int argc,char *argv[]){
		int a[10];
		int b[] = {10,20,30};
		printf("sizeof(a) = %d\n",sizeof(a));
		return 0;
}

初始化

全部初始化 int a[5] = {1,2,3,4,5};

部分初始化,赋值不够的后面补0 int a[5] = 2;

#include<stdio.h>
int main(){
    // 如果不初始化,直接使用为随机值
    int a[4] = {2,3,6,5};
    printf("数组a的元素为:%d,%d,%d,%d\n",a[0],a[1],a[2],a[3]);
    int b[4] = {2,5};
    printf("数组b的元素为:%d,%d,%d,%d\n",b[0],b[1],b[2],b[3]);
}

3.2 二维数组

格式: 数据类型 数组名[行的个数][列的个数]

例如 int a[2][4]

解释:名为a的二维数组,每个元素都是int类型,包含两行四列元素,一共有8个元素

二维数组也是连续开辟空间,访问元素是行和列都是从0开始

分别是 a[0][0] , a[0][1]…a[1][3]

注意:二维数组的行数可以省略,列数不能省略,在初始化的时候按照如下操作

系统会根据列数自动指定行数

#include<stdio.h>
int main(){
    int a[2][4];
    printf("sizeof(a)=%ld %ld\n",sizeof(a),2 * 4 *sizeof(int));
    // 省略行标:
    int b[][4] = {1,2,3,4,5};
    printf("sizeof(b)= %ld\n",sizeof(b));
    return 0;
}

初始化

逐行初始化:

#include<stdio.h>
int main(){
    int a[2][3] = {{1,2,3},{6,6,6}};
    int i = 0,j = 0;
    for(i = 0;i < 2;i++){
        for(j = 0;j < 3;j++){
            printf("%d,",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}

部分初始化:

#include<stdio.h>
int main(){
    int a[2][3] = {{1,2},{6}};
    int i = 0,j = 0;
    for(i = 0;i < 2;i++){

        for(j = 0;j < 3;j++){
            printf("%d,",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}

全局初始化:

#include<stdio.h>
int main(){
    int a[2][3] = {1,2,3,4,5,6};
    int i = 0,j = 0;
    for(i = 0;i < 2;i++){
        for(j = 0;j < 3;j++){
            printf("%d,",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}

4.数组元素的引用方法

一维数组:数组名[下标]

二维数组:数组名[行标][列标]

上例中已经通过a[ i ][ j ]进行引用,简单易懂

5.字符数组的定义

#include<stdio.h>
int main(){
    // 用字符的方式赋值
    char c1[] = {'c',' ','p','i','g'};
    printf("c1数组为:\n");
    for(int i = 0;i < 5;i++){
        printf("'%c',",c1[i]);
    }
    printf("\n");
    // 用字符串的方式赋值,多占1个字节,用于存放结束标志 ‘\0'
    char c2[] = "c pig";
    for(int j = 0;j < 6;j++){
        printf("'%c',",c2[j]);
    }
    // 二维数组  字符赋值
    char a[][5] = {
        {'a','b','v','g','y'},
        {'a','b','v','g','y'}
    };
    // 字符串赋值,知道为什么是6吗? 因为多了一个 '\0'
    char b[][6] = {"hello","world"};
    // 二维数组的元素读者可自行打印练习
    return 0;
}

练习:定义一个字符数组,通过scanf函数输入字符串并输出结果

#include<stdio.h>
int main(){
    //通过赋值”“这样的方式可以清除字符数组中的垃圾字符,让每一个元素都是 \0
    char ch[32] = "";
    printf("请输入一个字符串:\n");
    scanf("%s",ch);   //数组名就是当前数组的首地址
    printf("ch = %s\n",ch);
    return 0;
}

到此这篇关于C语言从基础到进阶全面讲解数组的文章就介绍到这了,更多相关C语言数组内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C语言三种方法解决轮转数组问题

    目录 题目 1.题目描述 2.要求 3.原题链接 二.相关知识点 三.解决思路 旋转法 直接法 空间换取时间 题目 1.题目描述 给你一个数组,将数组中的元素向右轮转 k 个位置,其中 k 是非负数. 示例 1: 输入: nums = [1,2,3,4,5,6,7], k = 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5,6] 向右轮转 2 步: [6,7,1,2,3,4,5] 向右轮转 3 步: [5,6,7,1,2,3,4] 2.要求 进阶

  • C语言全方位讲解指针与地址和数组函数堆空间的关系

    目录 一.一种特殊的变量-指针 二.深入理解指针与地址 三.指针与数组(上) 四.指针与数组(下) 五.指针与函数 六.指针与堆空间 七.指针专题经典问题剖析 一.一种特殊的变量-指针 指针是C语言中的变量 因为是变量,所以用于保存具体值 特殊之处,指针保存的值是内存中的地址 内存地址是什么? 内存是计算机中的存储部件,每个存储单元有固定唯一的编号 内存中存储单元的编号即内存地址 需要弄清楚的事实 程序中的一切元素都存在于内存中,因此,可通过内存地址访问程序元素. 内存示例 获取地址 C语言中通

  • C语言详细讲解多维数组与多维指针

    目录 一.指向指针的指针 二.二维数组与二维指针 三.数组名 四.小结 一.指向指针的指针 指针的本质是变量 指针会占用一定的内存空间 可以定义指针的指针来保存指针变量的地址值 为什么需要指向指针的指针? 指针在本质上也是变量 对于指针也同样存在传值调用与传址调用 下面看一个重置动态空间大小(从 size 到 new_size)的代码: #include <stdio.h> #include <malloc.h> int reset(char** p, int size, int

  • C语言零基础讲解指针和数组

    目录 一.指针和数组分析-上 1.数组的本质 2.指针的运算 3.指针的比较 4.小结 二.指针与数组分析-下 1.数组的访问方式 2.下标形式 VS 指针形式 3.a 和 &a 的区别 4.数组参数 5.小结 一.指针和数组分析-上 1.数组的本质 数组是一段连续的内存空间 数组的空间大小为 sizeof(array_type) * array_size 数组名可看做指向数组第一个元素的常量指针 下面看一段代码: #include <stdio.h> int main() { int

  • C语言 从根本上理解数组

    目录 一.数组的概念 二.数组的大小 三.数组地址与数组名 四.数组名的盲点 五.小结 一.数组的概念 数组是相同类型的变量的有序集合 二.数组的大小 数组在一片连续的内存空间中存储元素 数组元素的个数可以显示或隐式指定 下面看一段数组初始化的代码: #include <stdio.h> int main() { int a[5] = {1, 2}; int b[] = {1, 2}; printf("a[2] = %d\n", a[2]); printf("a[

  • C语言 栈与数组的实现详解

    目录 栈的实现 栈的定义 数组实现 静态栈 动态栈 链栈 栈的实现 首先我们思考一个问题,什么是栈? 栈是数据结构的一种,栈在我们日常编码中遇到的非常多,很多人对栈的接触可能仅仅局限在 递归使用的是栈 和 StackOverflowException,栈是一种后进先出的数据结构(可以想象生化金字塔的牢房和生化角斗场的狗洞). 栈的定义 栈(stack)又名堆栈,它是一种运算受限的线性表.限定仅在表尾进行插入和删除操作的线性表.这一端被称为栈顶,相对地,把另一端称为栈底.向一个栈插入新元素又称作进

  • C语言数组的各种操作梳理

    目录 一.一维数组 1.创建 2.初始化 3.使用 4.数组在内存中的存储 5.数组大小的计算 二.二维数组 1.创建 2.初始化 3.使用 4.二维数组在内存中的存储 三.数组作为函数参数 1.关于数组名是数组首元素的地址的两个例外 2.冒泡排序 一.一维数组 1.创建 //如何创建数组 int num[10]; char arr[10]; double sum[10]; float fix[10]; //变长数组 //数组的大小是变量 //C99语法支持 int a = 10; int ar

  • C语言深入分析数组指针和指针数组的应用

    目录 一.数组类型 二.定义数据类型 三.数组指针 四.指针数组 五.小结 一.数组类型 C语言中的数组有自己特定的类型 数组的类型由元素类型和数组大小共同决定 例:int array[5] 的类型为 int[5] 二.定义数据类型 C语言中通过 typedef 为数组类型重命名:typedef type(name)[size]; 数组类型: typedef int(AINT5)[5]; typedef float(AFLOAT10)[10]; 数组定义: AINT5 iArray; AFLOA

  • C语言 详细讲解数组参数与指针参数

    目录 一.C语言中的数组参数退化为指针的意义 二.二维数组参数 三.等价关系 四.被忽视的知识点 五.小结 一.C语言中的数组参数退化为指针的意义 C 语言中只会以值拷贝的方式传递参数 当向函数传递数组时: 将整个数组拷贝一份传入函数        × 将数组名看做常量指针传数组首元素地址    √ C 语言以高效作为最初设计目标: a) 参数传递的时候如果拷贝整个数组执行效率将大大下降. b) 参数位于栈上,太大的数组拷贝将导致栈溢出. 二.二维数组参数 二维数组参数同样存在退化的问题 二维数

  • C语言从基础到进阶全面讲解数组

    目录 1.基础知识 2.数组的分类 2.1按元素类型分类 2.2按维数分类 3.数组定义和初始化 3.1 一维数组 3.2 二维数组 4.数组元素的引用方法 5.字符数组的定义 1.基础知识 C语言中使用数组表示多个连续的同类型的存储位置 使用数组表示多个连续存储位置的时候只需要一个名字,这个名字代表所有这些存储位置的整体 每一个存储位置有一个自己的编号,最前边的存储位置的编号是0,向后依次递增,最后一个存储位置的编号是个数减一,这个编号叫做下标 决不可以使用超过范围的下标 使用名称和下标就可以

  • C语言数据的存储超详细讲解上篇

    目录 前言 1.数据类型介绍 类型的基本归类 2.整形在内存中的存储 2.1 原码.反码.补码 2.2 大小端介绍 2.2.1 什么是大小端 2.2.2 大端和小端意义 2.2.3 写程序判断字节序 总结 前言 本文开始学习C语言进阶的内容了,进阶内容,是在基础阶段的内容上进行拓展,有的知识点,在基础阶段也已经学过.在进阶内容中,将从更深层次的角度去理解学习,本文主要内容包括: 数据类型详细介绍 整形在内存中的存储:原码.反码.补码 大小端字节序介绍及判断 浮点型在内存中的存储解析 1.数据类型

  • 无线标记语言(WML)基础之WMLScript 基础第1/2页

    WML Script是属于无限应用协议WAP应用层的一部分,使用它可以向WML卡片组和卡片中添加客户端的处理逻辑,目前最新的版本是1.1版.WML Script1.1是在欧洲计算机制造商协议会制定的ECMAScript脚本语言的基础上,经过修改和优化而指定的.它能够更好的支持诸如移动电话类的乍带宽通信设备,在WML编程中使用WML Script可以有效的增强客户端应用的灵活性,而且,我们也可以把WML Script作为一个工具使用,开发出功能强大的WAP网络应用和无限网页.本章我们将详细讲解WM

  • WAP建站WML语言语法基础教程第1/6页

    完成WAP服务器的建立和WAP浏览器的安装之后,我们接下来就可以使用WML语言来编写WAP网页或应用,并通过WAP服务器及浏览器进行调试.从本章开始我们将系统地学习WML语言,本章主要讲解WML语言的基础知识,下一章全面讲解WML的语法.标签和规则. 2.1 WML的简单例子及编辑.测试方法 无限标记语言WML(Wireless Markup Language)是一种基于扩展标记语言XML(Extension Markup Language)的语言,是XML的子集.它可以显示各种文字.图像等数据

  • C语言函数基础教程分类自定义参数及调用示例详解

    目录 1.  函数是什么? 2.  C语言中函数的分类 2.1 库函数 2.1.1 为什么要有库函数 2.1.2 什么是库函数 2.1.3 主函数只能是main()吗 2.1.4常见的库函数 2.2 自定义函数 2.2.1自定义函数是什么 2.2.2为什么要有自定义函数 2.2.3函数的组成 2.2.4 举例展示 3. 函数的参数 3.1 实际参数(实参) 3.2  形式参数(形参) 4. 函数的调用 4.1 传值调用 4.2  传址调用 4.3 练习 4.3.1. 写一个函数判断一年是不是闰年

  • C语言数据的存储超详细讲解下篇浮点型在内存中的存取

    目录 前言 浮点型在内存中的存储 浮点数存储的例子 浮点数存储规则 IEEE 754规定 IEEE 754对有效数字M的特别规定 IEEE 754对指数E的特别规定 存入内存是E的规定 从内存取出时E的规定 举例 1 举例 2 举例 3 判断两个浮点数是否相等? 总结 前言 本文接着学习数据的存储相关的内容,主要学习浮点型数在内存中的存储与取出. 浮点型在内存中的存储 常见的浮点数:3.14159.1E10 浮点数家族包括: float.double.long double 类型 浮点数表示的范

  • Go语言单元测试基础从入门到放弃

    目录 Go语言测试 go test工具 单元测试函数 格式 单元测试示例 go test -v go test -run 回归测试 跳过某些测试用例 子测试 表格驱动测试 介绍 示例 并行测试 使用工具生成测试代码 测试覆盖率 testify/assert 安装 使用示例 总结 Go语言测试 这是Go单测从入门到放弃系列教程的第0篇,主要讲解在Go语言中如何做单元测试以及介绍了表格驱动测试.回归测试,并且介绍了常用的断言工具. go test工具 Go语言中的测试依赖go test命令.编写测试

  • Oracle PL/SQL语言入门基础

    正在看的ORACLE教程是:Oracle PL/SQL语言入门基础.PL/SQL是ORACLE对标准数据库语言的扩展,ORACLE公司已经将PL/SQL整合到ORACLE 服务器和其他工具中了,近几年中更多的开发人员和DBA开始使用PL/SQL,本文将讲述PL/SQL基础语法,结构和组件.以及如何设计并执行一个PL/SQL程序. PL/SQL的优点 从版本6开始PL/SQL就被可靠的整合到ORACLE中了,一旦掌握PL/SQL的优点以及其独有的数据管理的便利性,那么你很难想象ORACLE缺了PL

  • 基于JS脚本语言的基础语法详解

    JS脚本语言的基础语法:输出语法  alert("警告!");  confirm("确定吗?");   prompt("请输入密码");为弱类型语言: 开始时要嵌入JS代码:<script type="text/javascript"></script>: 关于写程序是需注意的基本语法: 1.所有的字符全都是英文半角的: 2.大部分情况下每条语句结束后要加分号: 3.每一块代码结束后加换行:4.程序前呼

随机推荐