04数组

作者: 忘带充电宝de皮卡丘 | 来源:发表于2018-05-28 18:15 被阅读0次

[注] 使用数组的目的,是为了方便地批量定义变量

[前言] c语言中提供了数组,可以实现批量地定义相同类型的变量,在我们需要多个相同类型的变量时,可以选择使用数组

数组分为两类:一维数组,二维数组

一、一维数组

1.一维数组的定义

类型符 数组名[元素个数];

类型符,可以是int,char,double等等这些基本数据类型,类型符决定了数组中多个变量的类型

数组名,数组名必须符合标识符的命名规则

元素个数,表示数组一次性定义的变量的个数(数组中包含的元素个数)

​ 例如:int array[4];

2.一维数组---元素表示

int array[4];

[注] 数组中元素的下标是从0开始的

​ array[0]

3.一维数组的特点

  • 数组中每个元素的类型都相同

  • 数组中每个元素是由数组名和下标唯一确定的

  • 数组元素下标从0开始,最大到元素个数减1

  • 数组元素之间是紧密相连的

盖住数组名,剩下的部分就是数组的类型

数组所占总内存空间,是由数组的类型决定的

4.一维数组---初始化

数组的初始化的目的,是为了让数组中每个元素都有一个确定的值

//完全初始化
int array[4]={1,2,3,4};
//部分初始化
int array[4]={1,2};//编译器会优先取初始化列表中的值给数组前面的元素赋值,那些未显示初始化的元素默认初始化为0
//数组清空
int array[400]={};

5.一维数组---赋值

//一维数组---赋值
int array[4]={1,2,3,4};
//数组不能整体赋值,只能单个元素单独赋值
array2[0]=10;
array2[1]=array[1];
//通过循环,依次读取数据给数组的每个元素赋值
for (int i=0; i<4; i++)
{
    scanf("%d",&array[i]);
}

6.数组下标问题

数组元素的下标是从0开始的

1.数组下标

数组定义时,数组的下标表示的是数组中元素的个数

2.数组元素的下标

使用数组元素时,下标表示的是元素在数组中的位置

3.数组下标越界问题

数组下标使用的合法范围为:0~元素个数-1

数组下标越界可能会导致程序终止

[注] 在程序运行过程中如果发生以下报错信息,一般都是数组使用越界导致的---Thread 1:signal SIGABRT

7.数组排序

int array[10]={7,2,6,3,4,9,5,1,8,10};

冒泡法

思想:

  • 数组中待排序数,从左往右,依次取两两相邻的元素进行比较,前一个元素大于后一个元素,就交换这两个元素

  • 第一趟比较完毕时,所有参与排序元素中最大值放在所有元素的结尾

  • 重复以上步骤,直到所有元素排序完毕

//外层循环,控制比较的趟数
for (int i=1; i<10; i++)
{
    //内层循环,控制具体某一趟的比较次数
    for (int j=0; j<10-i; j++)
    {
        if (array[j]<array[j+1])
        {
            //交换相邻的两个元素
            //交换的主角是array[j]和array[j+1]
            int temp;
            temp=array[j];
            array[j]=array[j+1];
            array[j+1]=temp;
        }
    }
}
//打印数组中的每个元素
for(int i=0;i<10;i++)
{
    printf("%d ",array[i]);
}

选择法

思想:

  • 取数组中未排序元素中最左边的元素,依次和右边其他元素进行比较,如果前一个比后一个大,交换两个元素
  • 第一趟比较完毕时,所有参与排序元素中最小元素,放在所有参与排序元素的最左边
  • 重复以上步骤,直到所有元素排序完毕
//外层循环,控制比较的趟数
for (int i=0; i<9; i++)
{
    //内层循环,控制具体某一趟的比较次数
    for (int j=i+1; j<10; j++)
    {
        if (array[i]>array[j])
        {
            //交换相邻的两个元素
            //交换的主角是array[i]和array[j]
            int temp;
            temp=array[i];
            array[i]=array[j];
            array[j]=temp;
        }
    }
}
//打印数组中的每个元素
for(int i=0;i<10;i++)
{
    printf("%d ",array[i]);
}

二、二维数组

1.二维数组的定义

类型符 数组名[元素个数][元素的元素个数];

例子:

int arr[4][4];//这是一个二维数组,这个二维数组具有4个元素,每个元素的类型是int[4]

2.二维数组---元素表示

int arr[4][4];

元素:arr[0],arr[1],arr[2],arr[3]

第一个元素arr[0]

第二个元素arr[1]

第三个元素arr[2]

第四个元素arr[3]

3.二维数组---初始化

//完全初始化
int array[3][3] = {{1,2,3},{4,5,6},{7,8,9}};
int array2[3][3] = {{1,2},{4,5,6},{}};
int array3[3][3] = {{},{},{}};
//部分初始化
int array4[3][3] = {{1,2}};

4.其他

二维数组赋值

数组不能整体赋值,只能单个元素单独赋值.

array4[0] = array3[0];

二维数组在使用过程中,数组元素下标不能越界访问.

三、练习

1.将一个5元素数组中元素,相邻的两两相加,找出最大的组合;打印出是哪两个元素

int a[5],sum=0,b=0,x=0,y=0;
for (int i=0; i<5; i++)
{
    scanf("%d",&a[i]);
}
for (int i=0; i<4; i++)
{
    sum=a[i]+a[i+1];
    if (sum>b)
    {
        b=sum;
        x=a[i];
        y=a[i+1];
    }
}
printf("%d %d\n",x,y);

2.输入10个数,相邻的两个绝不相同。输出每个递增递减序列,并输出有多少个这种序列

1 2 3 2 4 5 6 7 6 3

1 2 3

3 2

2 4 5 6 7

7 6 3

总共:4

#include <stdio.h>

int main(int argc, const char * argv[])
{
    int a[10],n=1;
    for (int i=0; i<10; i++)
    {
        scanf("%d",&a[i]);
    }
    for (int i=1; i<9; i++)
    {
        if ((a[i-1]-a[i]<0&&a[i]-a[i+1]<0)||(a[i-1]-a[i]>0&&a[i]-a[i+1]>0))
        {
            printf("%d %d ",a[i-1],a[i]);
        }
        else
        {
            printf("%d %d\n",a[i-1],a[i]);
            n++;
        }
    }
    printf("\n总共:%d\n",n);
    return 0;
}

相关文章

  • JS数组与集合

    2019-04-18 一维数组 创建 语法格式一:数组名 = new Array(数组元素1,数组元素2… …);...

  • 第07天C语言(00):笔记总结

    01-数组-内存存储细节 02-数组-注意点 03-数组-练习1 04-函数和数组1 05-数组和函数2 06-数...

  • 数组二

    ackage com.itheima_04;/* * 数组获取最值(获取数组中的最大值最小值) */public ...

  • 剑指Offer(一)

    题目汇总03.数组中重复的数字(简单),本题考查数组04.二维数组中的查找(简单),本题考查数组05.替换空格,本...

  • Serial Port

    2018-04-1316进制转化字节数组 字节数组转化为16进制字符串

  • LeetCode | 面试题04. 二维数组中的查找【剑指Off

    LeetCode 面试题04. 二维数组中的查找【剑指Offer】【Easy】【Python】【数组】 问题 力扣...

  • 11 数组

    数组的定义 01 动态初始化 02 静态初始化 03 省略格式及初始化注意事项 04 获取数组 05 动态数组初始...

  • 遍历数组找出最大值

    package HspLearningArray; public class Array04 {//请求出一个数组...

  • 第四天 数组【悟空教程】

    第四天 数组【悟空教程】 第04天 Java基础 第1章数组 1.1数组概念 软件的基本功能是处理数据,而在处理数...

  • es5数组新增方法详解

    http://www.zhangxinxu.com/wordpress/2013/04/es5新增数组方法/

网友评论

    本文标题:04数组

    本文链接:https://www.haomeiwen.com/subject/fszgjftx.html