C学习笔记-数组
数组的概念
数组是一组具有相同数据类型的变量集合,这里要注意两点,数组只能存储相同的数据类型和数组的内存是连续的,这位数组和指针的联系奠定了基础。
一维数组
定义及初始化
一维数组指的是只有一个下标的数组,它用来表示一组具有相同类型的数据
其格式为
类型说明符 数组名[常量表达式];
e.g.
int arr[3];
上式表达的是定义了一个一维数组,其数据类型是int,arr是数组名称,3表示的是数组长度。其包含的为arr[0],arr[1],arr[2],没有arr[3],使用arr[3]会造成数组越界错误
数组的初始化有三种方式:
- 直接对数组按位数初始化
int arr[3] = {1, 2, 3};
- 初始化部分元素,此时剩余元素默认设置为0
int arr[3] = {1, 2};
- 不指定数组长度,此时长度会自动按照元素个数赋值
int arr[] = {1, 2, 3};
一维数组的使用
要使用数组元素,就需要使用符合数组使用规则的使用方式,数组使用格式如下:
数组名[下标]
注:在数组中,下标是以0开始的
- 一维数组的遍历
数组中的一个常见操作就是对数组进行遍历
int arr[3] = { 1, 2, 3};
int i = 0;
for (i = 0; i < 3; i++)
{
printf("arr[%d] = %d\n", i, arr[i]);
}
- 获取一维数组的最值
最值得获取也是一维数组的常见操作
假设第一个值是最大值,然后依次和后面的值对比,通过不断替换从而得到最大值
int arr[5] = {1, 6, 7, 2, 5};
int max = arrx[0];
int i = 0;
for (i = 1; i < 5; i++)
{
if (arr[i] > max)
{
max = x[i];
}
}
printf("max = %d\n", max);
- 一维数组的排序
一维数组有一个很重要的应用就是排序,排序中有两个排序比较重要,面试什么的最喜欢的。一个是冒泡排序,一个是选择排序。- 冒泡排序原理

- 从第一个元素开始,将相邻的两个元素依次进行比较,直到最后两个元素完成比较。如果前一个元素比后一个元素大,则交换它们的位置。整个过程完成后,数组中最后一个元素自然就是最大值,这样也就完成了第一轮的比较。
- 除了最后一个元素,将剩余的元素继续进行两两比较,过程与第一步相似,这样就可以将数组中第二大的数放在倒数第二个位置。
- 依次类推,持续对越来越少的元素重复上面的步骤,直到没有任何一对元素需要比较为止
- 冒泡排序原理
int x[5] = { 9, 8, 3, 5, 2 };
int m = 0, n = 0;
int temp = 0;
int i = 0;
printf("冒泡排序前:\n");
for (i = 0; i < 5; i++)
{
printf("%d ", x[i]);
}
printf("\n");
for (m = 0; m < 5 - 1; m++)
{
for (n = 0; n < 5 - 1 - m; n++)
{
if (x[n] > x[n + 1])
{
temp = x[n];
x[n] = x[n + 1];
x[n + 1] = temp;
}
}
}
printf("冒泡排序后:\n");
for (i = 0; i < 5; i++)
{
printf("%d ", x[i]);
}
printf("\n");
二维数组
定义及初始化
二维数组可以看作一维数组的每个元素又是一个一维数组,其格式为:
类型说明符 数组名[常量表达式1][常量表达式2];
e.g.:
int arr[2][3];
二维数组的初始化:
- 按行赋值
int arr[2][3] = {{1, 2 ,3}, {4, 5, 6}};
- 综合赋值
int arr[2][3] = {1, 2, 3, 4, 5, 6};
- 部分赋值
int arr[2][3] = {{1},{1, 2, 3}};
注:对数组赋值时,二维数组的第一个下标可以省略,而第二个下标不可省略!
arr <=> *arr <=> &arr <=> &arr[0][0] <=> array[0]
在二维数组中。arr[0]代表的是一个数组名,是一个右值。
arr + 1与arr[0] + 1代表的意义不同
二维数组的使用
二维数组的使用规则与一维数组类似,其格式为
数组名[下标][下标];
- 二维数组的遍历
int arr[3][4] = { {1,2,3,4 }, {5,6,7,8}, {9,10,11,12} };
for (int i = 0; i < 3; i++) //循环遍历行
{
for (int j = 0; j < 4; j++) //循环遍历列
{
printf("arr[%d][%d] = %d \t", i, j, arr[i][j]);
}
printf("\n");//每一行的末尾添加换行符
}
C学习笔记-数组的更多相关文章
- Java菜鸟学习笔记--数组篇(三):二维数组
定义 //1.二维数组的定义 //2.二维数组的内存空间 //3.不规则数组 package me.array; public class Array2Demo{ public static void ...
- JavaScript学习笔记-数组
数组 数组中的每个元素的位置是索引,索引是基于32位的由0开始的数值,最大索引为(2的32次方-2),最大长度为(2的32次方-3) 数组是无类型的:元素可为任意类型:动态的:可根据需要自动增长.缩减 ...
- JavaScript学习笔记——数组
javascript数组数组是一个可以存储 一组 或是 一系列 相关数据 的 容器. 一.为什么要使用数组. (1)为了解决大量相关数据的存储和使用的问题. (2)模拟真是的世界. 二.如何创建数组 ...
- JavaScript学习笔记-数组(1)
数组是值的有序集合.每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引.JavaScript数组是无类型的:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有不同的类型.数 ...
- Java菜鸟学习笔记--数组篇(二):数组实例&args实例
基本类型实例 //1.定义一个一维数组,先声明,在分配空间 int []number;//生命,没有初始化,number=null number=new int[5];//初始化为默认值,int默认值 ...
- js学习笔记——数组方法
join() 把数组中所有元素转化为字符串并连接起来,并返回该字符串, var arr=[1,2,3]; var str=arr.join("#"); //str="1# ...
- JS学习笔记-数组
ECMAScript中没有提供类和接口等的定义,但它却是一门面向对象的语言,由于它能够通过其它 方式实现类似高级语言的面向对象功能,这些内容将在后面的文章中进行一步步的总结.此篇仅对JS中对象作简要说 ...
- PHP学习笔记-数组(1)
1-1 数组定义 1.什么是数组? 所谓数组,就是相同数据类型的元素按一定顺序排列的集合,就是把有限个类型相同的变量用一个名字命名,然后用编号区分他们的变量的集合,这个名字称为数组名,编号称为下标.组 ...
- php 学习笔记 数组3
15.使用数组 1).并集(union) array_merge(array1,array2,array3..) 函数把两个或多个数组合并为一个数组,后面覆盖前面 2). 交集(intersecti ...
- php 学习笔记 数组2
10.切割数组 array_slice(array, offset, length);返回一个由原始数组中的连续元素组成的新数组,参数1为原始数组,参数2为要复制的起始位置, 参数3要复制的个数:新数 ...
随机推荐
- struts2模糊查询
dao层 public interface DimDao { //一个条件 public List<User> userdim(User user); //两个条件且关联表格 public ...
- css(name|pro|[,val|fn])
css(name|pro|[,val|fn]) 概述 访问匹配元素的样式属性.大理石平台支架 jQuery 1.8中,当你使用CSS属性在css()或animate()中,我们将根据浏览器自动加上前缀 ...
- 51 Nod 1287 加农炮(单调队列思想+二分)
1287 加农炮 题目来源: Codility 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 一个长度为M的正整数数组A,表示从左向右的地形高度 ...
- [bat]只更新svn部分文件夹
游戏工程里的sdk文件夹,经常被svn认定为有毒文件. 后来关了权限之后,已拉取过的sdk文件夹还是会拉下来. 网上找了个方法,bat文件只更新部分文件. TortoiseProc /command: ...
- Docker容器常用命令汇总
Docker常用命令总结如下: # 查看docker详细信息 docker info # 获取当前节点所有容器 docker ps -a # 管理容器生命周期 docker [start|stop|r ...
- 软件开发中什么是CI/CD
持续集成(Continuous integration)是一种软件开发实践,每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误. 持续部署(continuous d ...
- Java如何接收前端传来的多层嵌套的复杂json串
想看问题直接解决方式,直接拉到博文底部. Spring的controller在接收前端传参的时候如果参数使用@RequestBody标注的时候 @RequestBody 则会把前端参数转为JSON的形 ...
- 关于AngularJS与其他前端框架混合使用的思考
AngularJS 是一个为动态WEB应用设计的结构框架,拥有双向数据绑定,模板,MVVM,依赖注入,指令5大优点,Angular最有诱惑力的就是数据绑定功能,使用MVC模式进行开发,Angular在 ...
- httpClinent工具类
package com.juchn.gateway.common.utils; import java.io.BufferedReader; import java.io.IOException; i ...
- 只要你用atom修改后保存代码文件的时候,你在chrome上的页面就会自动刷新。
学习html和css的时候Ctrl+s 以后预览网页需要手动刷新 现在不用了 给chrome安装安装LivePage这个插件. 只要你用atom修改后保存代码文件的时候,你在chrome上的页面就会自 ...