文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么进行C语言中数组的使用

2023-06-22 06:18

关注

怎么进行C语言中数组的使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

1 数组的基本概念

2 数组定义语法

数组类型 数组名[数组大小]

3 一维数组的初始化

3.1 全部初始化

int arr[5] = {1, 2, 3, 4, 5};//arr[0]:1//arr[1]:2//arr[2]:3//arr[3]:4//arr[4]:5

3.2 部分元素赋初值

int arr[5] = {1, 2, 3};//arr[0]:1//arr[1]:2//arr[2]:3//arr[3]:0//arr[4]:0

实际开发中,通常采用部分元素赋初值的方法对数组元素进行初始化,如:int arr[100]={0};

3.3 省略长度赋初值

int arr[] = {1, 2, 3, 4, 5};

定义数组时,如果后面跟有初始化列表,并且初始化列表中的值的个数就是预期的数组大小,则可省略括号中的数组大小。

4 一维数组的使用示例

4.1 求最大值、最小值、平均值

#include <stdio.h>int main(void){    int arr[10];    int 1, sum, max, min;    //命令行读取10个整数    for(i=0; i<10; i++)    {        scanf("%d", &arr[i]);    }    //求平均值、求最大值、最小值    sum = 0;    max = arr[0];    min = arr[0];    for(i=0; i<10; i++)    {        sum += arr[i];        if(max < arr[i])        {            max = arr[i];        }        if(min>arr[i])        {            min = arr[i];        }    }    printf("平均值为:%.2f", sum/10.0);    printf("最大值为:%d", max);    printf("最小值为:%d", min);}

4.2 数组逆置

#include<stdio.h>int main(void){    int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};    int i, temp;    //数组逆置    for(i=0; i<10/2; i++){        temp = arr[i];        arr[i] = arr[10-i-1];        arr[10-i-1] = temp;    }    //输出    for(i=0; i<10; i++){        printf("%d\n", arr[i]);    }}

4.3 数组排序

4.3.1 冒泡排序

排序:5, 7, 1, 4, 9, 2, 10, 3, 8, 6

第一次:5,1,4,7,2,9,3,8,6,|10

第二次:1,4,5,2,7,3,8,6,|9,10

第三次:1,4,2,5,3,7,6,|8,9,10

第四次:1,2,4,3,5,6,|7,8,9,10

第五次:1,2,3,4,5,|6,7,8,9,10

第六次:1,2,3,4,|5,6,7,8,9,10

第七次:1,2,3,|4,5,6,7,8,9,10

第八次:1,2,|3,4,5,6,7,8,9,10

第九次:1,|2,3,4,5,6,7,8,9,10

#include<stdio.h>int main(void){    int arr[10] = {5, 7, 1, 4, 9, 2, 10, 3, 8, 6};    int i, j, temp;    //冒泡排序    for(i=0; i<10-1; i++){        for(j=0; j<10-i-1; j++){            if(arr[j]>arr[j+1]){                temp = arr[j];                arr[j] = arr[j+1];                arr[j+1] = temp;            }        }    }    //输出    for(i=0; i<10; i++){        printf("%d\n", arr[i]);    }}
4.3.2 选择排序 选择列表中的最小值与未排序列表中的第一个值互换位置。

排序:5, 7, 1, 4, 9, 2, 10, 3, 8, 6

第一次:1,|7,5,4,9,2,10,3,8,6

第二次:1,2,|5,4,9,7,10,3,8,6

第三次:1,2,3,|4,9,7,10,5,8,6

第四次:1,2,3,4,|9,7,10,5,8,6

第五次:1,2,3,4,5,|7,10,9,8,6

第六次:1,2,3,4,5,6,|10,9,8,7

第七次:1,2,3,4,5,6,7,|9,8,10

第八次:1,2,3,4,5,6,7,8,|9,10

第九次:1,2,3,4,5,6,7,8,9,|10

#include<stdio.h>int main(void){    int arr[10] = {5, 7, 1, 4, 9, 2, 10, 3, 8, 6};    int i, j, min, temp;    //选择排序    for(i=0; i<10-1; i++){        min = i;        for(j=i+1; j<10;j++){            if(arr[min]>arr[j]){                min = j;            }        }        if(min != j){            temp = arr[i];            arr[i] = arr[min];            arr[min] = temp;        }    }    //输出    for(i=0; i<10; i++){        printf("%d\n", arr[i]);    }}
4.3.3 直接插入排序

每次都无序列表中选择第一个元素,与有序列表中最后一个元素开始逐一比较,在比它小的元素后面插入该元素。

排序:5, 7, 1, 4, 9, 2, 10, 3, 8, 6

第一次:5,7,|1, 4, 9, 2, 10, 3, 8, 6

第二次:1,5,7,|4, 9, 2, 10, 3, 8, 6

第三次:1,4,5,7,|9, 2, 10, 3, 8, 6

第四次:1,4,5,7,9,|2, 10, 3, 8, 6

第五次:1,2,4,5,7,9,|10, 3, 8, 6

第六次:1,2,4,5,7,9,10,|3, 8, 6

第七次:1,2,3,4,5,7,9,10, | 8, 6

第八次:1,2,3,4,5,7,8,9,10, |6

第九次:1,2,3,4,5,6,7,8,9,10

#include<stdio.h>int main(void){    int arr[10] = {5, 7, 1, 4, 9, 2, 10, 3, 8, 6};    int i, j, temp;    //直接插入排序    for(i=1; i<10; i++){        temp = arr[i];//保存无序列表中的第一个元素        for(j=i-1; j>=0 && arr[j]>temp; --j){            arr[j+1] = arr[j];//比该元素大的元素均往后移一位        }           arr[j+1] = temp;    }    //输出    for(i=0; i<10; i++){        printf("%d\n", arr[i]);    }}

5 二维数组

5.1 二维数组的概念

二维数组就是存放一维数组的一维数组。本质上可以理解为二维数组就是一个一维数组,只不过这个一维数组里面的每一个元素都是一个一维数组。

int arr[3][4];//相当于定义一个3行4列的二维数组

相当于一个长度为3的一维数组,这个一维数组里面每个元素的长度是:长度为4的整形一维数组。

5.2 二维数组的初始化

5.2.1 全部初始化 按行全部赋初值
int arr[2][3] = {{1, 2, 3}, {4, 5, 6}};

顺序全部赋初值

int arr[2][3] = {1, 2, 3, 4, 5 ,6};
5.2.2 部分初始化

按行部分赋初值

int arr[2][3] = {{1, 2}, {4}};

顺序部分赋初值

int arr[3][4] = {1, 2, 3, 4};
5.2.3 省略长度初始化

可省略行数,不可省略列数。按行

int arr[][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};//arr[3][3]int brr[][3] = {{1, 2}, {3, 4}};//brr[2][3]

按顺序

int arr[][3] = {1, 2, 3 ,4, 5};//arr[2][3]

6 二维数组示例

6.1 二维数组的遍历

#include<stdio.h>int main(void){   int arr[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};   int i, j;   for(i=0; i<3; i++){       for(j=0; j<4; j++){            printf("%d ", arr[i][j]);       }       printf("\n");   }}

6.2 求平均成绩

#include<stdio.h>int main(void){       int arr[3][4], i, j, sum;    double aver1[3], aver2[4];    for(i=0; i<3; i++){        switch(i){        case 0:            printf("高数成绩:\n");            break;        case 1:            printf("英语成绩:\n");            break;        case 2:            printf("C语言成绩:\n");            break;        }        for(j=0; j<4; j++){            scanf("%d", &arr[i][j]);        }    }    //求每一科的平均成绩    for(i=0; i<3; i++){        sum = 0;        for(j=0; j<4; j++){            sum+=arr[i][j];        }          aver1[i] = sum/4.0;    }    //求每个人的平均成绩    for(i=0; i<4; i++){        sum = 0;        for(j=0; j<3; j++){            sum+=arr[j][i];        }          aver2[i] = sum/3.0;    }    for (i=0; i<3; i++) {        switch (i) {        case 0: printf("高数"); break;        case 1: printf("英语"); break;        case 2: printf("C语言"); break;        }        printf("的平均成绩为:%.2f\n", aver1[i]);    }    printf("------------------------\n");    for (i=0; i<4; i++) {        switch (i) {        case 0: printf("张三"); break;        case 1: printf("李四"); break;        case 2: printf("王五"); break;        case 3: printf("赵六"); break;        }        printf("的平均成绩为:%.2f\n", aver2[i]);    }    return 0;}

7 一维字符数组与字符串

7.1 字符数组

char ch[5] = {'a', 'b', 'c', 'd', 'e'};

7.2 字符串的保存

char s1[6] = {'a', 'b', 'c', 'd', 'e', '\0'};char s2[6] = "abcde";//s1与s2初始化效果相同

7.3 字符串的读取与打印

char str[100];//输入 ni hao ascanf("%s", str); //打印 niprintf("%s\n", str);
char str[100];gets(str); puts(str);

看完上述内容,你们掌握怎么进行C语言中数组的使用的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯