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

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 凡人这期给大家带来十一道牛客网oj题,都是对C语言新手很友好的题目,而且把详细的过程写了下来,让大家可以学会这些题目,大家可以点进去练习练习,战胜对编程的恐惧

目录

前言

BC13 ASCII码

描述

输入描述:

输出描述:

解析:

BC14 出生日期输入输出

输出描述:

示例1

解析:

BC29 2的n次方计算

描述

输入描述:

输出描述:

示例1

解析:

BC15 按照格式输入并交换输出

描述

输入描述:

输出描述:

示例1

解析:

BC16 字符转ASCII码

描述

输入描述:

输出描述:

示例1

解析:

BC17 计算表达式的值

描述

输入描述:

输出描述:

解析:

BC18 计算带余除法

描述

输入描述:

输出描述:

示例1

分析:

BC25 计算体重指数

描述

输入描述:

输出描述:

示例1

解析:

BC26 计算三角形的周长和面积

描述

输入描述:

输出描述:

示例1

解析:

BC27 计算球体的体积

描述

输入描述:

输出描述:

示例1

解析:

BC10 成绩输入输出

描述

输入描述:

输出描述:

示例1

解析:

总结



前言

凡人这期给大家带来十一道牛客网oj题,都是对C语言新手很友好的题目,而且把详细的过程写了下来,让大家可以学会这些题目,大家可以点进去练习练习,战胜对编程的恐惧


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

BC13 ASCII码

描述

BoBo教KiKi字符常量或字符变量表示的字符在内存中以ASCII码形式存储。BoBo出了一个问题给KiKi,转换以下ASCII码为对应字符并输出他们。

73, 32, 99, 97, 110, 32, 100, 111, 32, 105, 116 , 33

输入描述:

输出描述:

一行输出转换题目中给出的所有ASCII码对应的字符,无需以空格隔开。

解析:

1,定义数组,数组是存放同一类型的,可以把以上数字都放进去

2,求出数组里面的个数,用总的大小除去一个的大小就是个数

3,用for循环把数组里面的内容以字符打印出来,注意数组是用下标访问,从0开始

代码如下:

#include<stdio.h>
int main()
{
    //定义数组,把数字放进去
    int arr[] = {73, 32, 99, 97, 110, 32, 100, 111, 32, 105, 116 , 33};
    int i = 0;
    //计算数组有多少个元素
    int sz = sizeof(arr)/sizeof(arr[0]);
    //打印出来
    for(i=0;i<sz;i++)
    {
        printf("%c",arr[i]);
    }
    return 0;
}

BC14 出生日期输入输出

输出描述:

三行,第一行为出生年份,第二行为出生月份,第三行为出生日期。输出时如果月份或天数为1位数,需要在1位数前面补0。

示例1

输入:

20130225

输出:

year=2013

month=02

date=25

解析:

1,定义年月日

2,输入年月日三个数,分别控制4位,2位,2位

3,输出年月日,注意月和日在填写一位数的时候要自动填充0

代码如下:

#include<stdio.h>
int main()
{
    int year = 0;
    int month = 0;
    int day = 0;
    scanf("%4d%2d%2d",&year,&month,&day);
    printf("year=%4d\n",year);
    printf("month=%02d\n",month);
    printf("date=%02d",day);
    return 0;
}


BC29 2的n次方计算

描述

不使用累计乘法的基础上,通过移位运算(<<)实现2的n次方的计算。

数据范围:0 \le n \le 31 \0≤n≤31

输入描述:

一行输入整数n(0 <= n < 31)。

输出描述:

输出对应的2的n次方的结果。

示例1

输入:

  2                10

复制输出:

  4                1024

解析:

1,定义一个数并且输入

2,输出一个数对应的2的n次方的结果,而且要用<<操作符,1<<1 是代表1的二进制向左位移1位,结果为2,是2的1次,1<<2代表1的二进制向左位移2位,结果为4,是2的2次,推理可得,1<<n代表2的n次,左移操作符,左移一位有乘2的效果

代码如下:

#include<stdio.h>
int main()
{
    int n = 0;
    scanf("%d",&n);
    printf("%d",1<<n);
    return 0;
}


BC15 按照格式输入并交换输出

描述

输入两个整数,范围-231~231-1,交换两个数并输出。

输入描述:

输入只有一行,按照格式输入两个整数,范围,中间用“,”分隔。

输出描述:

把两个整数按格式输出,中间用“,”分隔。

示例1

输入:

a=1,b=2

输出:

a=2,b=1

解析:

1,定义两个数并且输入两个数

2,交换两个数需要定义一个临时变量,先把a里的值给了c,然后把b的值给了a,最后把c的值给了b,这样就完成了两个数的交换

3,按照格式输出交换后的结果

代码如下:

#include<stdio.h>
int main()
{
    int a = 0;
    int b = 0;
    int c = 0;
    scanf("a=%d,b=%d",&a,&b);
    c = a;
    a = b;
    b = c;
    printf("a=%d,b=%d",a,b);
    return 0;
}


BC16 字符转ASCII码

描述

BoBo教KiKi字符常量或字符变量表示的字符在内存中以ASCII码形式存储。BoBo出了一个问题给KiKi,输入一个字符,输出该字符相应的ASCII码。

输入描述:

一行,一个字符。

输出描述:

一行,输出输入字符对应的ASCII码。

示例1

输入:

c

输出:

99

解析:

1,因为是字符,所以char定义,并且用getchar接收

2,要字符的ASCII码值,直接以%d的形式打印就好

代码如下:

#include<stdio.h>
int main()
{
    char ch = 0;
    ch = getchar();
    printf("%d",ch);
    return 0;
}


BC17 计算表达式的值

描述

请计算表达式“(-8+22)×a-10+c÷2”,其中,a = 40,c = 212。

输入描述:

无。

输出描述:

(-8+22)×a-10+c÷2计算之后的结果,为一个整数。

解析:

1,定义表达式中的a与c

2,输出表达式就好,注意乘除的符号

代码如下:

#include<stdio.h>
int main()
{
    int a = 40;
    int c = 212;
    printf("%d",(-8+22)*a-10+c/2);
    return 0;
}


BC18 计算带余除法

描述

给定两个整数a和b (0 < a,b < 10,000),计算a除以b的整数商和余数。

输入描述:

一行,包括两个整数a和b,依次为被除数和除数(不为零),中间用空格隔开。

输出描述:

一行,包含两个整数,依次为整数商和余数,中间用一个空格隔开。

示例1

输入:

15 2

输出:

7 1

分析:

1,定义两个数,被除数和除数,并输入

2,打印商和余数,考察/操作符与%操作符,除法与取余操作符

代码如下:

#include<stdio.h>
int main()
{
    int a = 0;
    int b = 0;
    scanf("%d %d",&a,&b);
    printf("%d %d",a/b,a%b);
    return 0;
}


BC25 计算体重指数

描述

问题:计算BMI指数(身体质量指数)。BMI指数(即身体质量指数,简称体质指数又称体重,英文为Body Mass Index,简称BMI),是用体重公斤数除以身高米数平方得出的数字,是目前国际上常用的衡量人体胖瘦程度以及是否健康的一个标准。主要用于统计用途,当我们需要比较及分析一个人的体重对于不同高度的人所带来的健康影响时,BMI值是一个中立而可靠的指标

数据范围:输入的数据满足 50 \le n \le 180 \50≤n≤180

输入描述:

一行,两个整数,分别表示体重(公斤),身高(厘米),中间用一个空格分隔。

输出描述:

一行,BMI指数(保留两位小数)。

示例1

输入:

70 170

输出:

24.22

解析:

1,定义身高和体重并且输入两个值

2,看题,需要求bmi值,而题中的bmi指数是用体重公斤数除以身高米数平方得出的数字,定义一个bmi,注意这个数字是小数,需要float或者double,因为需要身高米数,所以除以一个100.0,因为要得出的数是小数

3,输出,注意,要保留2位小数,所以是.2f

代码如下:

#include<stdio.h>
int main()
{
    int high = 0;
    int weight = 0;
    float BMI = 0.0;
    scanf("%d %d",&weight,&high);
    BMI = weight/((high/100.0)*(high/100.0));
    printf("%.2f",BMI);
    return 0;
}


BC26 计算三角形的周长和面积

描述

根据给出的三角形3条边a, b, c,计算三角形的周长和面积。

数据范围: 0 < a,b,c \le 100000 \0<a,b,c≤100000

输入描述:

一行,三角形3条边(能构成三角形),中间用一个空格隔开。

输出描述:

一行,三角形周长和面积(保留两位小数),中间用一个空格隔开,输出具体格式详见输出样例。

示例1

输入:

3 3 3

输出:

circumference=9.00 area=3.90

解析:

1,定义三角形的三条边,并输入三个数

2,求三角形的周长,先定义三角形周长等于三条边加起来

3,求三角形的面积,这时候就需海伦公式了,不熟悉的同学可以点进去看看,海伦公式需要一个变量p 而p等于周长除以2,然后套用公式S=√p(p-a)(p-b)(p-c)来求面积,注意,在C语言中有一个库函数sqrt()来专门求开平方

4,按照格式具体输出,注意保留两位数

代码如下:

#include<stdio.h>
int main()
{
    double a = 0.0; //边长
    double b = 0.0;
    double c = 0.0;
    scanf("%lf %lf %lf",&a,&b,&c);
    double circumference = a+b+c;//周长
    double p = circumference/2.0;
    double area = sqrt(p*(p-a)*(p-b)*(p-c));//面积
    printf("circumference=%.2lf area=%.2lf",circumference,area);
    return 0;
}

BC27 计算球体的体积

描述

给定一个球体的半径,计算其体积。其中球体体积公式为 V = 4/3*πr3,其中 π = 3.1415926。

数据范围:输入一个浮点值 0 \le n \le 15 \0≤n≤15

输入描述:

一行,用浮点数表示的球体的半径。

输出描述:

一行,球体的体积,小数点后保留3位。

示例1

输入:

3.0

输出:

113.097

解析:

1,定义半径并输入半径,注意,double的精度要比float的高,所以一般用double,在这道题用float是精度不够的

2,定义球体体积,把π定义好,并且套用球体体积公式,注意,体积要求是小数,所以得有一个小数

3,输出体积,注意取小数点三位,.3lf

代码如下:

#include<stdio.h>
int main()
{
    double r = 0.0;  //半径
    scanf("%lf",&r);
    double V = 0.0; //体积
    double pi = 3.1415926;
    V = 4.0/3*pi*r*r*r;
    printf("%.3lf",V);
    return 0;
}


BC10 成绩输入输出

描述

输入3科成绩,然后把三科成绩输出,成绩为整数形式。

数据范围: 0 \le n \le 100 \0≤n≤100

输入描述:

一行,3科成绩,用空格分隔,范围(0~100)。

输出描述:

一行,把3科成绩显示出来,输出格式详见输出样例。

示例1

输入:

60 80 90

输出:

score1=60,score2=80,score3=90

解析:

1,定义三门成绩,并输入,可以单独定义,也可以使用数组来定义

2,输入三门成绩,可以分别定义,也可以for循环遍历数组输入成绩,这样更方便

3,输出成绩

代码如下:两种

#include<stdio.h>
int main()
{
    int a = 0;
    int b = 0;
    int c = 0;
    scanf("%d %d %d",&a,&b,&c);
    printf("score1=%d,score2=%d,score3=%d",a,b,c);
    return 0;
}
int main()
{
    int arr[3] = {0};
    int i = 0;
    for(i=0;i<3;i++)
    {
        scanf("%d",&arr[i]);
    }
    printf("score1=%d,score2=%d,score3=%d",arr[0],arr[1],arr[2]);
    return 0;
}

总结

以上就是带来的十一道牛客入门oj题目与每道题的解析,这些都是针对新手的友好题目,有哪里不懂的,可以评论区留言,大佬也可以指点一二,求三连,凡人在这里感谢大家观看!

相关文章
|
2月前
|
存储 C语言 C++
【c语言】运算符汇总(万字解析)
今天博主跟大家分享了c语言中各种操作符的功能、使用方法以及优先级和结合性,并且与大家深入探讨了表达式求值的两个重要规则--算数转换和整形提升。学习这些知识对我们的C语言和C++学习都有着极大的帮助。
123 2
|
28天前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
129 14
|
1月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
47 8
|
1月前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
427 6
|
1月前
|
存储 网络协议 算法
【C语言】进制转换无难事:二进制、十进制、八进制与十六进制的全解析与实例
进制转换是计算机编程中常见的操作。在C语言中,了解如何在不同进制之间转换数据对于处理和显示数据非常重要。本文将详细介绍如何在二进制、十进制、八进制和十六进制之间进行转换。
39 5
|
1月前
|
C语言 开发者
【C语言】断言函数 -《深入解析C语言调试利器 !》
断言(assert)是一种调试工具,用于在程序运行时检查某些条件是否成立。如果条件不成立,断言会触发错误,并通常会终止程序的执行。断言有助于在开发和测试阶段捕捉逻辑错误。
41 5
|
1月前
|
安全 搜索推荐 Unix
【C语言】《回调函数》详细解析
回调函数是指一个通过函数指针调用的函数。它允许将一个函数作为参数传递给另一个函数,并在特定事件发生时执行。这种技术使得编程更加灵活,可以动态决定在何时调用哪个函数。
43 1
|
2月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
87 2
|
10天前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
|
10天前
|
设计模式 存储 安全
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析
结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象结构型模式比类结构型模式具有更大的灵活性。 结构型模式分为以下 7 种: • 代理模式 • 适配器模式 • 装饰者模式 • 桥接模式 • 外观模式 • 组合模式 • 享元模式
【23种设计模式·全精解析 | 创建型模式篇】5种创建型模式的结构概述、实现、优缺点、扩展、使用场景、源码解析

推荐镜像

更多