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


目录
相关文章
|
2月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
187 6
|
3月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
3月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
99 5
|
3月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
3月前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。
|
C语言
我们要掌握好多少C语言知识点才能做好C语言项目?
我们要掌握好多少C语言知识点才能做好C语言项目?
1268 0
|
1月前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
37 3
|
1月前
|
存储 算法 安全
【C语言程序设计——函数】分数数列求和1(头歌实践教学平台习题)【合集】
if 语句是最基础的形式,当条件为真时执行其内部的语句块;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。常量的值必须是唯一的,且在同一个。
20 2
|
1月前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
66 16
|
1月前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
52 1

热门文章

最新文章