C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)(上)

简介: C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)
  1. 一维数组

数组,即为一组相同类型的元素的集合;

1.1 一维数组的创建

数组的创建

① type_t:数组的元素类型;

② arr_name:数组名;

③ const_n:常量表达式,用于指定数组大小;

注意事项

① 数组创建,[ ] 中要给定常量,不能使用变量;

② 数组 [ ] 中的内容如果不指定大小(不填),则需要初始化;

一维数组创建方法演示

const_n中要给定一个常量,不能使用变量

int main()
{
    int count = 10;
    int arr[count]; // error
    
    return 0;
}
#define N 10
int main()
{
    int arr2[N]; // yes
    
    return 0;
}

1.2 一维数组的初始化

初始化:在创建数组的同时给数组的内容置一些合理的初始值;

int main()
{
    int arr1[10];  // 创建一个大小为10的int类型数组
    char arr2[20]; // 创建一个大小为20的char类型数组
    float arr3[1]; // 创建一个大小为1的float类型数组
    double arr4[] = { 0 }; // 创建一个不指定大小的double类型数组(需要初始化)
 
    return 0;
}

1.3 字符数组初始化

int main()
{
    char ch1[5] = {'b', 'i', 't'};
    char ch2[] = {'b', 'i', 't'};
 
    char ch3[5] = "bit";  // 'b', 'i', 't', '\0', '0'
    char ch4[] = "bit";  // 'b', 'i', ''t, '\0'
 
    return 0;
}

字符数组初始化的两种写法

双引号写法自带斜杠0,花括号写法不自带斜杠0(需要手动添加)
int main()
{
    char ch5[] = "bit"; // b, i, t, \0
    char ch6[] = {'b', 'i', 't'}; // b i t
    printf("%s\n", ch5);
    printf("%s\n", ch6);
 
    return 0;
}

没有 \0 时,strlen读取时并不会知道什么时候结束(继续往后面读,直到遇到斜杠0),

strlen:遇到斜杠0就停止

int main()
{
    char ch5[] = "bit"; // b, i, t, \0      【自带斜杠0】
    char ch6[] = {'b', 'i', 't'}; // b i t  【不自带斜杠0】
    printf("%d\n", strlen(ch5));//3
    printf("%d\n", strlen(ch6));//随机值
 
    return 0;
}

当然,你可以给他手动加上一个斜杠0,这样就不会是随机值了;

int main()
{
    char ch5[] = "bit"; // b, i, t, \0
    char ch6[] = {'b', 'i', 't', '\0'}; // b, i, t, + '\0'
    printf("%d\n", strlen(ch5));//3
    printf("%d\n", strlen(ch6));//3
 
    return 0;
}

1.4 一维数组的使用

下标引用操作符: [ ] ,即数组访问操作符;


数组的大小计算方法:整个数组的大小除以一个字母的大小

可以利用 for 循环,逐一打印数组

#include<stdio.h>
int main()
{
    int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
    int sz = sizeof(arr) / sizeof(arr[0]);
    for (int i = 0; i < sz; i++)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

总结:

① 数组是使用下标来访问的,下标从0开始;

② 可以通过计算得到数组的大小;

1.5 一维数组在内存中的存储

按地址的格式打印:%p (十六进制的打印)

#include<stdio.h>
int main()
{
    int arr[10] = { 0 };
    int sz = sizeof(arr) / sizeof(arr[0]);
    for (int i = 0; i < sz; i++)
    {
        printf("&arr[%d] = %p\n", i, &arr[i]);
    }
    return 0;
}

仔细检视输出结果可知:随着数组下标的增长,元素的地址也在有规律的递增;

结论:数组在内存中时连续存放的;


2. 二维数组

2.1 二维数组的创建

① const_n1:行

② const_n2: 列

#include<stdio.h>
int main()
{
    int arr1[3][4] = { 1 };//创建一个3行4列的int型二维数组;并给第一个元素赋值1,
    /*                   //只要赋值一个,后面的都是0,不赋值的话就是随机值
       0 0 0 0
       0 0 0 0
       0 0 0 0
    */                          
    printf("%d\n", arr1[0][0]);//1
    printf("%d\n", arr1[0][1]);//0
    char arr2[3][5];    // 创建一个3行5列的char型二维数组;
    double arr3[2][4];  // 创建一个2行4列的double型二维数组;
    return 0;
}

2.2 二维数组的初始化

初始化:在创建数组的同时给数组的内容置一些合理的初始值;

注意事项:

二维数组初始化时,行可以省略,但是列不可以省略;

② 二维数组在内存中也是连续存放的;

初始化演示

#include<stdio.h>
int main()
{
    int arr[3][4] = { 1,2,3,4,5 };
    /*
        1 2 3 4
        5 0 0 0
        0 0 0 0
    */
    int arr[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 }; // 完全初始化
    int arr2[3][4] = { 1,2,3,4,5,6,7 }; // 不完全初始化 - 后面补0;
    int arr3[3][4] = { {1,2}, {3,4}, {4,5} }; // 指定;
    /*
        1 2 0 0
        3 4 0 0
        4 5 0 0
    */
    return 0;
}

关于 " 行可以省略,列不可以省略 "

int main()
{
    int arr1[][] = {{2,3}, {4,5}};  // error
    int arr2[3][] = {{2,3}, {4,5}}; // error
    int arr2[][4] = {{2,3}, {4,5}}; // √
 
    return 0;
}

C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)(下):https://developer.aliyun.com/article/1512984


目录
相关文章
|
19天前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
40 8
|
19天前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
63 6
|
23天前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
44 5
|
23天前
|
C语言
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性。本文探讨了C语言中的错误类型(如语法错误、运行时错误)、基本处理方法(如返回值、全局变量、自定义异常处理)、常见策略(如检查返回值、设置标志位、记录错误信息)及错误处理函数(如perror、strerror)。强调了不忽略错误、保持处理一致性及避免过度处理的重要性,并通过文件操作和网络编程实例展示了错误处理的应用。
56 4
|
23天前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
27天前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
27天前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。
|
1月前
|
存储 人工智能 算法
数据结构实验之C 语言的函数数组指针结构体知识
本实验旨在复习C语言中的函数、数组、指针、结构体与共用体等核心概念,并通过具体编程任务加深理解。任务包括输出100以内所有素数、逆序排列一维数组、查找二维数组中的鞍点、利用指针输出二维数组元素,以及使用结构体和共用体处理教师与学生信息。每个任务不仅强化了基本语法的应用,还涉及到了算法逻辑的设计与优化。实验结果显示,学生能够有效掌握并运用这些知识完成指定任务。
51 4
|
2月前
|
存储 编译器 C语言
【c语言】数组
本文介绍了数组的基本概念及一维和二维数组的创建、初始化、使用方法及其在内存中的存储形式。一维数组通过下标访问元素,支持初始化和动态输入输出。二维数组则通过行和列的下标访问元素,同样支持初始化和动态输入输出。此外,还简要介绍了C99标准中的变长数组,允许在运行时根据变量创建数组,但不能初始化。
55 6
|
2月前
|
存储 算法 C语言
C语言:什么是指针数组,它有什么用
指针数组是C语言中一种特殊的数据结构,每个元素都是一个指针。它用于存储多个内存地址,方便对多个变量或数组进行操作,常用于字符串处理、动态内存分配等场景。