day6 作业

作业1:定义一个长度为20的数组,使用循环将斐波那契数列的前20项存到数组中,输出数组的每一项,并且输出该数组的总和。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int main(int argc, const char *argv[])
{
    int arr[20];
    int num1=1;
    int num2=1;
    int num;
    int sum=0;
    for(int i=0;i<20;i++)    //遍历数组
    {
        num=num1+num2;
        arr[i]=num1;       //把每一个数放到数组中
        num1=num2;
        num2=num;
    }
    printf("该数组为:");
    for(int i=0;i<20;i++)
    {
        sum=sum+arr[i];       //数组元素的求和
        printf("%d\t",arr[i]);
    }
    printf("\n");
    printf("数组的总和为:%d\n",sum);


    return 0;
}

作业2:通过键盘输入6名学生的成绩,输出6名学生的成绩,使用冒泡法对班级学生的成绩升序排序,输出排序后成绩。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>


int main(int argc, const char *argv[])
{
    int arr[6];
    int temp;
    printf("请输入6名学生的成绩:\n");
    for(int i=0;i<6;i++)
    {
        scanf("%d",&arr[i]);
    }
    printf("6名学生的成绩为:\n");
    for(int i=0;i<6;i++)
    {
        printf("%d\t",arr[i]);
        printf("\n");
    }
    for(int i=0;i<6;i++)           //冒泡排序两层循环
    {
        for(int j=0;j<6-i;j++)
        {
            if(arr[j]>arr[j+1])     
            {
                temp=arr[j];arr[j]=arr[j+1];arr[j+1]=temp; //交换三部曲
            }
        }
    }
    printf("排序后的成绩为:");
    for(int i=0;i<6;i++)
    {
        printf("%d\t",arr[i]);
    }
    printf("\n");
    return 0;
}

作业3:有如下两个数组: int arr[]= {1,2,3,4,5,6,7,8,9,0}; int brr[]= {3,7,15,9,20,2,100, 4};要求,自定义一个数组crr,将上面两个数组的交集存放到新数组中,并输出新数组中的内容。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>


int main(int argc, const char *argv[])
{
    int arr[]={1,2,3,4,5,6,7,8,9,0};
    int brr[]={3,7,15,9,20,2,100,4};
    int len=sizeof(arr)/sizeof(arr[0]);
    int crr[len];
    int k=0;
    for(int i=0;i<len;i++)
    {
        for(int j=0;j<len;j++)         //遍历两个数组的元素
        {
            if(brr[i]==arr[j])        //找交集
            {
                crr[k]=brr[i];       //把交集的元素放到一个新的数组里
                k++;
            }
        }
    }
    printf("新数组为:");
    for(int i=0;i<k;i++)
    {
        printf("%d\t",crr[i]);
    }
    printf("\n");

    return 0;
}

作业4:定义一个双精度浮点型数组,存放十个学生成绩,输入十名学生成绩,输出赋值后的所有元素。使用选择排序,完成降序排后输出,并求出平均分,统计出大于平均分学生的比重,输出结果。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>


int main(int argc, const char *argv[])
{
    double arr[10];
    double sum=0;
    int index;
    double temp;
    double avg;
    int count;
    printf("请输入10名学生的成绩:\n");
    for(int i=0;i<10;i++)
    {
        scanf("%lf",&arr[i]);
    }
    printf("这10名学生的成绩为:\n");
    for(int i=0;i<10;i++)
    {
        printf("%.2f\n",arr[i]);
    }
    for(int i=0;i<10;i++)
    {
        index=i;
        for(int j=i+1;j<10;j++)
        {
            if(arr[index]<arr[j])
            {
                index=j;
            }

        }
        if(index!=i)
        {
            temp=arr[i];arr[i]=arr[index];arr[index]=temp;   //交换三部曲
        }
    }
    printf("10名学生的成绩降序后:\n");
    for(int i=0;i<10;i++)
    {
        printf("%.2f\n",arr[i]);
        sum=sum+arr[i];
    }
    avg=sum/10;
    printf("这10名学生成绩的平均分为:%.2f\n",avg);
    for(int i=0;i<10;i++)
    {
        if(arr[i]>avg)
        {
            count++;
        }
    }
    printf("大于平均分的比重为:%.2f\n",(double)count/10);
    return 0;
}

作业5: 23031班有4个小组,每组有5名学生, C语言基础考试成绩,第一组5位同学的成绩为90、 92、93、 91、88, 第二组5位同学的成绩为86、89、87、 85、99, 第三组5位同学的成绩为100, 95,85, 75, 90, 四组5位同学的成绩为90,85, 85, 95,80,定义二维数组分别输入4个小组的成绩,利用循环再输出4个小组的学生成绩,求出每个小组的最低成绩,最高成绩并输出海个小组的最高成绩,最低成绩。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>


int main(int argc, const char *argv[])
{
    int arr[4][5];
    int max=0;
    int min=0;
    for(int i=0;i<4;i++)
    {
        for(int j=0;j<5;j++)
        {
            printf("请输入第%d组第%d个学生的成绩:",i+1,j+1);
            scanf("%d",&arr[i][j]);
        }
    }
    printf("学生的成绩为:\n");
    for(int i=0;i<4;i++)
    {
        for(int j=0;j<5;j++)
        {
            printf("%d\t",arr[i][j]);

        }
        printf("\n");
    }
    for(int i=0;i<4;i++)
    {
    max=arr[i][0];
    min=arr[i][0];

        for(int j=0;j<5;j++)
        {
            if(min>arr[i][j])
            {
                min=arr[i][j];
            }
            if(max<arr[i][j])
            {
                max=arr[i][j];
            }
        }
        printf("第%d组中最高分为:%d,最低分为:%d\n",i+1,max,min);
    
    }    
    return 0;
}

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值