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


目录
相关文章
|
23天前
|
存储 编译器 C语言
【C语言基础考研向】09 一维数组
数组是一种有序集合,用于存储相同类型的数据,便于统一操作与管理。例如,将衣柜底层划分为10个格子存放鞋子,便于快速定位。在C语言中,数组定义格式为 `类型说明符数组名[常量表达式];`,如 `int a[10];` 表示定义了一个包含10个整数的数组。数组初始化时可以直接赋值,也可以部分赋值,且数组长度必须固定。数组在内存中连续存储,访问时需注意下标范围,避免越界导致数据异常。数组作为参数传递时,传递的是首地址,修改会影响原数组。
|
23天前
|
存储 C语言
【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串
本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]=&quot;hello&quot;`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。
|
26天前
|
存储 人工智能 C语言
C语言程序设计核心详解 第六章 数组_一维数组_二维数组_字符数组详解
本章介绍了C语言中的数组概念及应用。数组是一种存储同一类型数据的线性结构,通过下标访问元素。一维数组定义需指定长度,如`int a[10]`,并遵循命名规则。数组元素初始化可使用 `{}`,多余初值补0,少则随机。二维数组扩展了维度,定义形式为`int a[3][4]`,按行优先顺序存储。字符数组用于存储字符串,初始化时需添加结束符`\0`。此外,介绍了字符串处理函数,如`strcat()`、`strcpy()`、`strcmp()` 和 `strlen()`,用于拼接、复制、比较和计算字符串长度。
|
1月前
|
消息中间件 Unix Linux
C语言 多进程编程(五)消息队列
本文介绍了Linux系统中多进程通信之消息队列的使用方法。首先通过`ftok()`函数生成消息队列的唯一ID,然后使用`msgget()`创建消息队列,并通过`msgctl()`进行操作,如删除队列。接着,通过`msgsnd()`函数发送消息到消息队列,使用`msgrcv()`函数从队列中接收消息。文章提供了详细的函数原型、参数说明及示例代码,帮助读者理解和应用消息队列进行进程间通信。
|
1月前
|
缓存 Linux C语言
C语言 多进程编程(六)共享内存
本文介绍了Linux系统下的多进程通信机制——共享内存的使用方法。首先详细讲解了如何通过`shmget()`函数创建共享内存,并提供了示例代码。接着介绍了如何利用`shmctl()`函数删除共享内存。随后,文章解释了共享内存映射的概念及其实现方法,包括使用`shmat()`函数进行映射以及使用`shmdt()`函数解除映射,并给出了相应的示例代码。最后,展示了如何在共享内存中读写数据的具体操作流程。
|
1月前
|
Linux C语言
C语言 多进程编程(七)信号量
本文档详细介绍了进程间通信中的信号量机制。首先解释了资源竞争、临界资源和临界区的概念,并重点阐述了信号量如何解决这些问题。信号量作为一种协调共享资源访问的机制,包括互斥和同步两方面。文档还详细描述了无名信号量的初始化、等待、释放及销毁等操作,并提供了相应的 C 语言示例代码。此外,还介绍了如何创建信号量集合、初始化信号量以及信号量的操作方法。最后,通过实际示例展示了信号量在进程互斥和同步中的应用,包括如何使用信号量避免资源竞争,并实现了父子进程间的同步输出。附带的 `sem.h` 和 `sem.c` 文件提供了信号量操作的具体实现。
|
C语言
我们要掌握好多少C语言知识点才能做好C语言项目?
我们要掌握好多少C语言知识点才能做好C语言项目?
1242 0
|
23天前
|
存储 Serverless C语言
【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数
本文介绍了C语言中的`gets`和`puts`函数,`gets`用于从标准输入读取字符串直至换行符,并自动添加字符串结束标志`\0`。`puts`则用于向标准输出打印字符串并自动换行。此外,文章还详细讲解了`str`系列字符串操作函数,包括统计字符串长度的`strlen`、复制字符串的`strcpy`、比较字符串的`strcmp`以及拼接字符串的`strcat`。通过示例代码展示了这些函数的具体应用及注意事项。
|
26天前
|
存储 C语言
C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数
本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。
|
26天前
|
存储 C语言
C语言程序设计核心详解 第七章 函数和预编译命令
本章介绍C语言中的函数定义与使用,以及预编译命令。主要内容包括函数的定义格式、调用方式和示例分析。C程序结构分为`main()`单框架或多子函数框架。函数不能嵌套定义但可互相调用。变量具有类型、作用范围和存储类别三种属性,其中作用范围分为局部和全局。预编译命令包括文件包含和宏定义,宏定义分为无参和带参两种形式。此外,还介绍了变量的存储类别及其特点。通过实例详细解析了函数调用过程及宏定义的应用。