5.C语言数组

==============

数组

==============

数组

        1.一维数组
        2.数组排序
        3.二维数组

一、什么是数组?

把具有相同类型的数据集合在一个连续的空间中。

二、一维数组

1.如何定义一维数组
用一个下标定位的数组。
2.一维数组的下标
从0开始,数组长度-1;
3.一维数组的赋值
4.越界访问
练习:
1》对一个长度为5的整型数组赋初值,并输出数组元素。

int arr[5] = {1,2,3,4,5};
//        printf("数组元素为:\n");
//        for (int i=0; i<5; i++) {
//            printf("%d ",arr[i]);
//        }

2》对一个长度为5的浮点型数组赋值,并逆序输出数组元素。

    float arr[5];
//        printf("请输入5个小数:");
//        for (int i=0; i<5; i++) {
//            scanf("%f",&arr[i]);
//        }
//        
//        printf("数组元素为:");
//        for (int i=4; i>=0; i--) {
//            printf("%.2f ",arr[i]);
//        }

3》求5个同学的总成绩、平均成绩、最高成绩、最低成绩。

    float score[5],sum=0,avg,max,min;
//        printf("请输入5个成绩:\n");
//        //循环遍历数组
//        for (int i=0; i<5; i++) {
//            printf("请输入第%d个成绩:",i+1);
//            scanf("%f",&score[i]);//输入成绩
//            sum+=score[i];  //求出总成绩
//        }
//        avg=sum/5;  //求出平均成绩
//        max=min=score[0];  //将第一个成绩赋值给最大最小的变量、
//        //遍历数组
//        for (int i=1; i<5; i++) {
//            //比较求出最大值
//            if (max<score[i]) {
//                max=score[i];
//            }
//            //比较求出最小值
//            if (min>score[i]) {
//                min=score[i];
//            }
//        }
//        //输出最终结果
//        printf("总成绩为:%.2f\n平均成绩为:%.2f\n最高成绩为:%.2f\n最低成绩为:%.2f\n",sum,avg,max,min);

4》输入10个数,打印出所有低于平均数的数。

//        int arr[10],sum=0;
//        float avg;
//        printf("请输入10个整数:");
//        for (int i=0; i<10; i++) {
//            scanf("%d",&arr[i]);
//            sum+=arr[i];
//        }
//        avg = sum/10.0;
//        for (int i=0; i<10; i++) {
//            if (arr[i]<avg) {
//                printf("%d ",arr[i]);
//            }
//        }

5》对一个长度为5的整型数组赋值,并将数组中的元素逆序

     int arr[5];
        printf("请输入5个整数:");
        for (int i=0; i<5; i++) {
            scanf("%d",&arr[i]);
        }
        //遍历数组:只遍历一半,因为数组元素前后都要交换。
        for (int i=0; i<5/2; i++) {
            //交换前后元素
            int t = arr[i];
            arr[i]=arr[5-1-i];  // 5 2 3 4 1
            arr[5-1-i]=t;
        }
        printf("数组元素如下:");
        for (int i=0; i<5; i++) {
            printf("%d ",arr[i]);
        }
    }

存放并输出。

三、数组排序

1.选择法
1.选择法

        int arr[5]={8,6,13,5,3};
        for (int i=0; i<5-1; i++) {
            for (int j=i+1;j<5;j++){
                if (arr[i]>arr[j]) {
                    int t=arr[i];
                    arr[i]=arr[j];
                    arr[j]=t;
                }
            }
        }
        for (int i=0; i<5; i++) {
            printf("%d ",arr[i]);
        }

2.冒泡法

      // 冒泡法
        int arr[5]={1,2,0,2,5};
            //从后往前
        for (int i=1; i<5; i++) { //控制比较次数
            //遍历数组
            for (int j=5; j>=i; j--) {
                if (arr[j]<arr[j-1]) {
                    int t=arr[j];
                    arr[j]=arr[j-1];
                    arr[j-1]=t;
                }
            }
        }
        //从前往后
      /*  for (int i=0; i<4; i++) {//控制比较次数
            for (int j=0; j<5-1-i; j++) {//从前往后遍历
                if (arr[j]>arr[j+1]) {
                    //交换
                    int t= arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=t;
                }
            }
        }
       */
        printf("数组元素如下 :");
        for (int i=0; i<5; i++) {
            printf("%d ",arr[i]);
        }
       
    }

练习:
1》输入5个学生的成绩,由高到低排序后输出

四、二维数组

1.如何定义二维数组
2.二维数组的下标
3.二维数组的赋值
练习:
1》对一个长度为3行2列的整型数组赋初值,并输出数组元素。
2》对一个长度为2行3列的浮点型数组赋值,并逆序输出数组元素。
3》分别求出两个班10个同学(每个班5个同学)的总成绩、平均成绩、最高成绩、最低成绩。
4》定义一个3行3列的整型数组并赋值,求出对角线的元素之和。
5》定义一个3行3列的整型数组并赋值,输出下列图形:
123 147 987 963
456 258 654 852
789 369 321 741

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容