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


目录
相关文章
|
1月前
|
存储 人工智能 程序员
一文彻底搞明白C语言的数组
本文详细介绍了C语言中的数组,包括定义、初始化(静态与动态)、存储方式、访问方法及常用操作,如遍历、修改元素和作为函数参数传递。数组是C语言中最基本的数据结构之一,掌握它对编程至关重要。下篇将介绍二维数组,敬请期待!
40 0
一文彻底搞明白C语言的数组
|
3月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
108 8
|
3月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
275 6
|
4月前
|
C语言 开发者
C语言中的模块化编程思想,介绍了模块化编程的概念、实现方式及其优势,强调了合理划分模块、明确接口、保持独立性和内聚性的实践技巧
本文深入探讨了C语言中的模块化编程思想,介绍了模块化编程的概念、实现方式及其优势,强调了合理划分模块、明确接口、保持独立性和内聚性的实践技巧,并通过案例分析展示了其应用,展望了未来的发展趋势,旨在帮助读者提升程序质量和开发效率。
136 5
|
4月前
|
C语言
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性。本文探讨了C语言中的错误类型(如语法错误、运行时错误)、基本处理方法(如返回值、全局变量、自定义异常处理)、常见策略(如检查返回值、设置标志位、记录错误信息)及错误处理函数(如perror、strerror)。强调了不忽略错误、保持处理一致性及避免过度处理的重要性,并通过文件操作和网络编程实例展示了错误处理的应用。
125 4
|
4月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
2月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
107 23
|
1月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
22 1
一文彻底搞清楚C语言的函数
|
2月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
124 15
|
2月前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
70 24