[百战成神7]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

[百战成神7]C语言之凡人暴刷小牛【超详细解析,掌握每道题】,第1张

 💘作者:你我皆为凡人

 💘博客主页:你我皆为凡人的博客

 💘名言警句:时间不会为任何人停留,而事物与人,无时不刻也在变化着。


每一个人,也都在不停向前!

 💘觉得博主文章写的不错的话,希望大家三连(✌关注,✌点赞,✌评论),多多支持一下!!

 💘系列作品:

💘[百战成神1]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

💘[百战成神2]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

💘[百战成神3]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

💘[百战成神4]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

💘[百战成神5]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

💘[百战成神6]C语言之凡人暴刷小牛【超详细解析,掌握每道题】

 

 

文章目录

目录

文章目录

前言

💘BC69 空心正方形图案

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛示例2

💛解析:

💘 代码如下:

💘BC70 空心三角形图案

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛示例2

💛解析:

💘 代码如下:

💘BC72 平均身高

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛解析:

💘 代码如下:

💘BC74 HTTP状态码

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛解析:

💘BC75 数字三角形

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛示例2

💛解析:

💘BC76 公务员面试

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛解析:

💘 代码如下:

💘BC77 有序序列插入一个数

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛解析:

💘 代码如下:

💘BC78 筛选法求素数

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛解析:

💘 代码如下:

💘BC79 图像相似度

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛解析:

💘 代码如下:

💘BC80 登录验证

💛描述

💛输入描述:

💛输出描述:

💛示例1

💛示例2

💛解析:

💘 代码如下:

总结


前言

内容超详细!!手把手教你如何去解析编程!如果你能听懂C语言,但是一上手就不会了,听完我讲解的题目后,相信你的写代码能力会逐步上升,战胜对编程的恐惧!


提示:以下是本篇文章正文内容,下面案例可供参考

💘BC69 空心正方形图案
💛描述

KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用“*”组成的“空心”正方形图案。


💛输入描述:

多组输入,一个整数(3~20),表示输出的行数,也表示组成正方形边的“*”的数量。


💛输出描述:

针对每行输入,输出用“*”组成的“空心”正方形,每个“*”后面有一个空格。


💛示例1

输入:

4

输出:

* * * * 
*     * 
*     * 
* * * * 
💛示例2

输入:

5

输出:

* * * * * 
*       * 
*       * 
*       * 
* * * * * 
💛解析:

🟥1,先定义一个整数n,然后多组输入,注意停止条件

🟥2,分析一下题,需要的条件

        🔹1,打印一个空心正方形图案

        🔹2,正方形是n行n列的,可以看到,如果定义i为行,j为列,如果当i等于第一行和最后一行,打印星号,如果j等于第一列与最后一列,打印信号,其余打印两个空格,打印完一行换行

💘 代码如下:
#include
int main()
{
    int n = 0;
    while (scanf("%d", &n) != EOF)
    {
        int i = 0;
        for (i = 0; i < n; i++)
        {
            int j = 0;
            for (j = 0; j < n; j++)
            {
                if (i == 0 || i == n - 1)
                {
                    printf("* ");
                }
                else if (j == 0 || j == n - 1)
                {
                    printf("* ");
                }
                else
                {
                    printf("  ");
                }
            }       
            printf("\n");
        }
    }
    return 0;
}
💘BC70 空心三角形图案

💛描述

KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用“*”组成的“空心”三角形图案。


💛输入描述:

多组输入,一个整数(3~20),表示输出的行数,也表示组成三角形边的“*”的数量。


💛输出描述:

针对每行输入,输出用“*”组成的“空心”三角形,每个“*”后面有一个空格。


💛示例1

输入:

4

输出:

*       
* *     
*   *   
* * * * 
💛示例2

输入:

5

输出:

*         
* *       
*   *     
*     *   
* * * * *
💛解析:

🟥1,先定义一个整数n,然后多组输入,注意停止条件

🟥2,分析一下题,需要的条件

        🔹1,打印一个空心三角形图案

        🔹2,正方形是n行n列的,为什么呢 ?因为这个空心三角形后面也有空格三角形,所以是n行n列,定义i行j列,如果当i是最后一行的时候,打印星号,如果当j是第一列的时候,如果当i和j相等是对角线的时候打印星号,否则打印空格,打印完一行然后输出

💘 代码如下:
  
#include
int main()
{
    int n = 0;
    while(scanf("%d",&n) != EOF)
    {
        int i = 0;
        for(i=0;i
💘BC72 平均身高

💛描述

从键盘输入5个人的身高(米),求他们的平均身高(米)。


💛输入描述:

一行,连续输入5个身高(范围0.00~2.00),用空格分隔。


💛输出描述:

一行,输出平均身高,保留两位小数。


💛示例1

输入:

1.68 1.75 1.82 1.60 1.92

输出:

1.75
💛解析:


🟥1,输入五个身高,空格分割,没有要求多组输入

🟥2,分析一下题,需要的条件

        🔹1,先输入五个身高,可以定义一个数组存放五个数的值,for循环遍历出每一个值,定义一个和,每次遍历完加到和里面去

        🔹2,打印出和除以5.0的结果,因为要保留两位小数

💘 代码如下:
#include
int main()
{
   int i = 0;
    float arr[5] = {0};
    float sum = 0;
    for(i=0;i<5;i++)
    {
        scanf("%f",&arr[i]);
        sum += arr[i];
    }
    printf("%.2f",sum/5.0);
    return 0;
}

 

💘BC74 HTTP状态码
💛描述

KiKi访问网站,得到HTTP状态码,但他不知道什么含义,BoBo老师告诉他常见HTTP状态码:200(OK,请求已成功),202(Accepted,服务器已接受请求,但尚未处理。


)400(Bad Request,请求参数有误),403(Forbidden,被禁止),404(Not Found,请求失败),500(Internal Server Error,服务器内部错误),502(Bad Gateway,错误网关)。


💛输入描述:

多组输入,一行,一个整数(100~600),表示HTTP状态码。


💛输出描述:

针对每组输入的HTTP状态,输出该状态码对应的含义,具体对应如下:
200-OK
202-Accepted
400-Bad Request
403-Forbidden
404-Not Found
500-Internal Server Error
502-Bad Gateway

💛示例1

输入:

200

输出:

OK
💛解析:


🟥1,定义一个整数,要求多组输入表示HTTP状态码

🟥2,分析一下题,需要的条件

        🔹如果用if语句显得太麻烦,最合适的就是Switch语句,然后根据题目要求一个一个输出,并且换行,记得要加上break语句,让跳出

💘 代码如下:

#include
int main()
{
    int n = 0;
    while(scanf("%d",&n) != EOF)
    {
        switch(n)
        {
            case 200:
                printf("OK\n");
                break;
            case 202:
                printf("Accepted\n");
                break;
            case 400:
                printf("Bad Request\n");
                break;
            case 403:
                printf("Forbidden\n");
                break;
            case 404:
                printf("Not Found\n");
                break;
            case 500:
                printf("Internal Server Error\n");
                break;
            case 502:
                printf("Bad Gateway\n");
                break;
        }
    }
    return 0;
}

 

💘BC75 数字三角形
💛描述

KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用数字组成的数字三角形图案。


💛输入描述:

多组输入,一个整数(3~20),表示数字三角形边的长度,即数字的数量,也表示输出行数。


💛输出描述:

针对每行输入,输出用数字组成的对应长度的数字三角形,每个数字后面有一个空格。


💛示例1

输入:

4

输出:

1
1 2
1 2 3
1 2 3 4
💛示例2

输入:

5

输出:

1
1 2
1 2 3
1 2 3 4
1 2 3 4 5
💛解析:


🟥1,定义一个整数,要求多组输入

🟥2,分析一下题,需要的条件

        🔹1,需要输出一个数字三角形

        🔹2,定义i表示行,从1开始,小于等于n,如果i从0开始的话就会多打印一个0,然后定义j表示列,从1开始,根据i来控制,如果i为1,打印1,如果i为2,打印1,2 打印完一行然后换行

💘 代码如下:

#include
int main()
{
    int n = 0;
    while(scanf("%d",&n) != EOF)
    {
        int i = 1;
        for(i=1;i<=n;i++)
        {
            int j = 1;
            for(j=1;j<=i;j++)
            {
                printf("%d ",j);
            }
                    printf("\n");
        }
    }
    return 0;
}

 

💘BC76 公务员面试
💛描述

公务员面试现场打分。


有7位考官,从键盘输入若干组成绩,每组7个分数(百分制),去掉一个最高分和一个最低分,输出每组的平均成绩。


(注:本题有多组输入)

💛输入描述:

每一行,输入7个整数(0~100),代表7个成绩,用空格分隔。


💛输出描述:

每一行,输出去掉最高分和最低分的平均成绩,小数点后保留2位,每行输出后换行。


💛示例1

输入:

99 45 78 67 72 88 60

输出:

73.00
💛解析:


🟥1,要求多组输入,每组7个成绩,去掉最高分和最低分

🟥2,分析一下题,需要的条件

        🔹1,一组要7个成绩,那么把7个成绩放到数组里存起来,然后多组输入,一次7个

        🔹2,定义一个i,把七个成绩遍历出来,放到和里面去,因为要减去一个最大值和最小值,那么假如最小值为100,如果比100小,那么最小值就是那个数,假如最大值为0,如果比0大,那么就调换,然后两位数小数打印,和减去最大值最小值然后除以5.0,因为要小数,所以是5.0,注意换行

💘 代码如下:
#include
int main()
{
    int arr[7] = {0};
    
    while(~scanf("%d %d %d %d %d %d %d",&arr[0],&arr[1],&arr[2],&arr[3],&arr[4],&arr[5],&arr[6]))
    {
        int i = 0;
        int max = 0;
        int min = 100;
        int sum = 0;
        for(i=0;i<7;i++)
        {
            sum += arr[i];
            if(arr[i]>max)
                max = arr[i];
            if(arr[i]
💘BC77 有序序列插入一个数
💛描述

有一个有序数字序列,从小到大排序,将一个新输入的数插入到序列中,保证插入新数后,序列仍然是升序。


💛输入描述:

第一行输入一个整数(0≤N≤50)。


第二行输入N个升序排列的整数,输入用空格分隔的N个整数。


第三行输入想要进行插入的一个整数。


💛输出描述:

输出为一行,N+1个有序排列的整数。


💛示例1

输入:

5
1 6 9 22 30
8

输出:

1 6 8 9 22 30
💛解析:


🟥1,要求从小到大排序,如果插入一个数,保证仍然是升序

🟥2,分析一下题,需要的条件

        🔹1,第一行,定义一个数,n,然后输入

        🔹2,第二行,输入n个升序排列的整数,因为n小于等于50,所以定义一个数组,放51个,然后遍历输入

        🔹3,第三行,输入一个要排序的数字

        🔹4,然后判断如何排序,如果把要排序的数字,从最后一个挨个向前比较,如果要排序的数字比这个数字小,那么原来位置上的数就+1,往后挪一个位,依次类推,如果大的话,那么这个数就放入排序的数字,但是如果当i小于0的时候,第一个元素就等于要排序的数字

        🔹5,打印并输出每个数字

💘 代码如下:
#include
int main()
{
    int n = 0;
    scanf("%d",&n);
    //第二行
    int i = 0;
    int arr[51] ={0};
    for(i=0;i=0;i--)
    {
        if(arr[i] > s)
        {
            arr[i+1] = arr[i];
        }
        else
        {
            arr[i+1] = s;
            break;
        }
    }
    if(i<0)
    {
        arr[0] = s;
    }
    for(i=0;i

 

💘BC78 筛选法求素数
💛描述

用筛选法求n以内的素数。


筛选法求解过程为:将2~n之间的正整数放在数组内存储,将数组中2之后的所有能被2整除的数清0,再将3之后的所有能被3整除的数清0 ,以此类推,直到n为止。


数组中不为0 的数即为素数。


💛输入描述:

多组输入,每行输入一个正整数(不大于100)。


💛输出描述:

针对每行输入的整数n,输出两行,第一行,输出n之内(包括n)的素数,用空格分隔,

第二行,输出数组中2之后被清0 的个数。


每行输出后换行。


💛示例1

输入:

20

输出:

2 3 5 7 11 13 17 19
11
💛解析:


🟥1,要求多组输入,每行输入一个正整数,不大于0

🟥2,分析一下题,需要的条件

        🔹1,要求筛选法求n以内的素数,

        🔹2,定义一个整数n,然后输入

        🔹3,先把2-n之间的数字给存储到数组里,因为n要求不大于100,所以定义101个刚好放下,然后定义i,从2开始遍历,把数组每个数换成i

        🔹4,然后要求将数组2以后所有能被2整除的数字清0,依次类推,先列举出所有除数,定义j,从2开始,一直到n,在定义一个k,要求从2以后,那么从j+1开始遍历,判断,假如从2-n,j等于2,那么k等于3,j等于3,k等于4,每一个k莫上一个j等于0的话,那么就能被整除,给换成0

        🔹5,然后第一行输出n之内的素数,如果这个数不等于0的时候,那么就代表没有被清0,就是素数,然后就打印下来,否则的话,count++,记录0的个数,然后打印第二行,先打印换行,然后输出0的个数

        🔹这道题还有一种是试除法,但是这个题目要求是筛选法,试除法代码放在下面了,大家可以看看,试除法比筛选法要简单一点

💘 代码如下:
#include
int main()
{
    int n = 0;
    while(scanf("%d",&n) != EOF)
    {
        //存储2-n的正整数
        int arr[101];
        int i = 0;
        for(i=2;i<=n;i++)
        {
            arr[i] = i; //把每个数给了i ,从2开始
        }
        //列举出除数
        int j = 0;
        for(j=2;j<=n;j++) //  2-n的数字当除数
        {
            int k = 0;
            for(k=j+1;k<=n;k++)//3,
            {
                if(arr[k]%j==0)//如果k=3,j=2  3%2=1
                {
                    arr[k]=0;//能被k整除
                }
            }
        }
        //输出并打印
        int count = 0;
        for(i=2;i<=n;i++)//输出n之内的素数
        {
            if(arr[i] != 0)//如果这个元素不等于0,那么就是素数
                printf("%d ",arr[i]);
            else
                count++;//否则的话,记录0的个数
        }
        //打印第二行
        printf("\n%d\n",count);
    }
    return 0;
}
#include
int main()
{
    int n = 0;
    while(scanf("%d",&n) != EOF)
    {
      //试除法
        //   2 3 4 5 6 7
        // 如果求2-7之间的素数  
        int arr[101];
        int i = 0;
        int count = 0;
        for(i=2;i<=n;i++)
        {
            //求素数
            int j = 0;
            for(j=2;j

 

💘BC79 图像相似度
💛描述

给出两幅相同大小的黑白图像(用0-1矩阵)表示,求它们的相似度。


若两幅图像在相同位置上的像素点颜色相同,则称它们在该位置具有相同的像素点。


两幅图像的相似度定义为相同像素点数占总像素点数的百分比。


💛输入描述:

第一行包含两个整数m和n,表示图像的行数和列数,用单个空格隔开。


1≤m≤100, 1≤n≤100。


之后m行,每行n个整数0或1,表示第一幅黑白图像上各像素点的颜色,相邻两个数用单个空格隔开。


之后m行,每行n个整数0或1,表示第二幅黑白图像上各像素点的颜色,相邻两个数用单个空格隔开。


💛输出描述:

一个实数,表示相似度(以百分比的形式给出),精确到小数点后两位。


💛示例1

输入:

3 3
1 0 1
0 0 1
1 1 0
1 1 0
0 0 1
0 0 1

输出:

44.44
💛解析:


🟥1,这道题一看题目,乍一看,好麻烦,可能连题目都看不懂,但是看例子发现,原来就是求相同的百分比

🟥2,分析一下题,需要的条件

        🔹1,第一行,定义m行与n列,并且输入

        🔹2,第二行,定义两个要比较的数组,m*n的比例,定义i与j来分别遍历输入

        🔹3,输出,判断,如果当两个数组有相同的时候,定义一个数,加一下,然后输出打印,需要保留两位小数,因为是百分比,所以100.0乘以count除以行与列的数

💘 代码如下:
#include
int main()
{
    int m = 0;
    int n = 0;
    int arr1[100][100] ={0};
    int arr2[100][100] ={0};
    scanf("%d %d",&m,&n);
    int i = 0;
    int j = 0;
    for(i=0;i

💘BC80 登录验证
💛描述

有个软件系统登录的用户名和密码为(用户名:admin,密码:admin),用户输入用户名和密码,判断是否登录成功。


💛输入描述:

多组测试数据,每行有两个用空格分开的字符串,第一个为用户名,第二个为密码。


💛输出描述:

针对每组输入测试数据,输出为一行,一个字符串(“Login Success!”或“Login Fail!”)。


💛示例1

输入:

admin admin

输出:

Login Success!
💛示例2

输入:

admin abc

输出:

Login Fail!
💛解析:


🟥1,要求多组输入,定义两个要输入的字符串,admin与password,用数组来存放,因为题中没有要求多大,存上一百应该足够了

🟥2,分析一下题,需要的条件

        🔹1,如果用户名与密码是admin的时候,输出登陆成功,那么字符串之间能不能进行比较呢,这个时候,有个专门的字符串比较库函数strcmp,如果用户名和admin比较返回值等于0的话,并且如果密码与admin比较等于0的话,输出登陆成功,否则的话登陆失败

💘 代码如下:
#include
#include
int main()
{
    char name[100] = {0};
    char password[100] = {0};
    while(scanf("%s %s",&name,&password) != EOF)
    {
        if((strcmp(name,"admin")==0) && (strcmp(password,"admin")==0))
        {
            printf("Login Success!\n");
        }
        else
        {
            printf("Login Fail!\n");
        }
    }
    return 0;
}

 

 


总结


剖析牛客编程题,让新手更加能够战胜对编程的恐惧,和凡人一起来解决这些题,刷爆牛客网上的题,现阶段是入门题,往后会开出新的专栏 ,一些复杂有难度的题,如果大家觉得凡人的文章还不错,值得观看收藏,希望大家一键三连,多多支持,有什么建议下方评论区留言,或者私信凡人,凡人一定听从意见,最后感谢大家观看!!!

 

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/634258.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-16
下一篇 2022-04-16

发表评论

登录后才能评论

评论列表(0条)