第一题 B2002 Hello,World!
题目描述
编写一个能够输出 Hello,World!
的程序。
提示:
- 使用英文标点符号;
Hello,World!
逗号后面没有空格。H
和W
为大写字母。
输入格式
无
输出格式
无
输入输出样例
输入 #1
无
输出 #1
Hello,World!
B2002 Hello,World!题解:
#include<iostream>//导入头文件iostream
using namespace std;//使用 命名空间 std
int main(){//定义函数main
cout<<"Hello,World!";//输出Hello,World
}
________________________________________________________
第二题 B2025 输出字符菱形
题目描述
用 *
构造一个对角线长 55 个字符,倾斜放置的菱形。
输入格式
没有输入要求。
输出格式
如样例所示。用 *
构成的菱形。
输入输出样例
输入 #1
输出 #1
* *** ***** *** *
B2025 输出字符菱形题解:
#include<cstdio>//导入工具箱cstdio
using namespace std;
int main(){
printf(" *\n");//输出 *并换行
printf(" ***\n");//输出 ***并换行
printf("*****\n");//输出*****并换行
printf(" ***\n");//输出 ***并换行
printf(" *");//输出 *
}
________________________________________________________
第三题 P1000 超级玛丽游戏
题目背景
本题是洛谷的试机题目,可以帮助了解洛谷的使用。
另外强烈推荐新用户必读贴
题目描述
超级玛丽是一个非常经典的游戏。请你用字符画的形式输出超级玛丽中的一个场景。
********
************
####....#.
#..###.....##....
###.......###### ### ###
........... #...# #...#
##*####### #.#.# #.#.#
####*******###### #.#.# #.#.#
...#***.****.*###.... #...# #...#
....**********##..... ### ###
....**** *****....
#### ####
###### ######
##############################################################
#...#......#.##...#......#.##...#......#.##------------------#
###########################################------------------#
#..#....#....##..#....#....##..#....#....#####################
########################################## #----------#
#.....#......##.....#......##.....#......# #----------#
########################################## #----------#
#.#..#....#..##.#..#....#..##.#..#....#..# #----------#
########################################## ############
输入格式
无
输出格式
如描述
输入输出样例
无
P1000 超级玛丽游戏题解:
#include<cstdio>
using namespace std;
int main(){
printf(" ********\n");
printf(" ************\n");
printf(" ####....#.\n");
printf(" #..###.....##....\n");
printf(" ###.......###### ### ###\n");
printf(" ........... #...# #...#\n");
printf(" ##*####### #.#.# #.#.#\n");
printf(" ####*******###### #.#.# #.#.#\n");
printf(" ...#***.****.*###.... #...# #...#\n");
printf(" ....**********##..... ### ###\n");
printf(" ....**** *****....\n");
printf(" #### ####\n");
printf(" ###### ######\n");
printf("##############################################################\n");
printf("#...#......#.##...#......#.##...#......#.##------------------#\n");
printf("###########################################------------------#\n");
printf("#..#....#....##..#....#....##..#....#....#####################\n");
printf("########################################## #----------#\n");
printf("#.....#......##.....#......##.....#......# #----------#\n");
printf("########################################## #----------#\n");
printf("#.#..#....#..##.#..#....#..##.#..#....#..# #----------#\n");
printf("########################################## ############\n");
return 0;
}
________________________________________________________
第四题 P1001 A+B Problem
题目背景
强烈推荐新用户必读帖。
不熟悉算法竞赛的选手请看这里:
算法竞赛中要求的输出格式中,不能有多余的内容,这也包括了“请输入整数 a 和 b” 这一类的提示用户输入信息的内容。若包含了这些内容,将会被认为是 Wrong Answer
,即洛谷上的 WA
。在对比代码输出和标准输出时,系统将忽略每一行结尾的空格,以及最后一行之后多余的换行符。
若因此类问题出现本机似乎输出了正确的结果,但是实际提交结果为错误的现象,请勿认为是洛谷评测机出了问题,而是你的代码中可能存在多余的输出信息。用户可以参考在题目末尾提供的代码。
此外,请善用应用中的在线 IDE 功能,以避免不同平台的评测产生差异。
最后,请不要在对应的题目讨论区中发布自己的题解,请发布到题解区域中,否则将处以删除或禁言的处罚。若发现无法提交题解则表明本题题解数量过多,仍不应发布讨论。若您的做法确实与其他所有题解均不一样,请联系管理员添加题解。
题目描述
输入两个整数 a,b,输出它们的和(≤109∣a∣,∣b∣≤109)。
注意
- Pascal 使用
integer
会爆掉哦! - 有负数哦!
- C/C++ 的 main 函数必须是
int
类型,而且 C 最后要return 0
。这不仅对洛谷其他题目有效,而且也是 NOIP/CSP/NOI 比赛的要求!
好吧,同志们,我们就从这一题开始,向着大牛的路进发。
任何一个伟大的思想,都有一个微不足道的开始。
输入格式
两个以空格分开的整数。
输出格式
一个整数。
输入输出样例
输入 #1
20 30
输出 #1
50
P1001 A+B Problem题解:
#include<cstdio>
using namespace std;
int main(){
int a,b;//声明变量a,b为int
scanf("%d%d",&a,&b);//输入a,b
printf("%d",a+b);//输出a,b的和
return 0;
}
________________________________________________________
第五题 B2005 字符三角形
题目描述
给定一个字符,用它构造一个底边长 5 个字符,高 3 个字符的等腰字符三角形。
输入格式
输入只有一行,包含一个字符。
输出格式
该字符构成的等腰三角形,底边长 5 个字符,高 3 个字符。
输入输出样例
输入 #1
*
输出 #1
* *** *****
说明/提示
对于 100% 的数据,输入的字符是 ASCII 中的可见字符。
B2005 字符三角形题解:
#include<cstdio>
using namespace std;
int main(){
char a;
scanf("%c",&a);
printf(" %c\n",a);
printf(" %c%c%c\n",a,a,a);
printf("%c%c%c%c%c\n",a,a,a,a,a);
return 0;
}
________________________________________________________
第六题 P5703 【深基2.例5】苹果采购
题目描述
现在需要采购一些苹果,每名同学都可以分到固定数量的苹果,并且已经知道了同学的数量,请问需要采购多少个苹果?
输入格式
输入两个不超过 109109 正整数,分别表示每人分到的数量和同学的人数。
输出格式
一个整数,表示答案。保证输入和答案都在 int 范围内的非负整数。
输入输出样例
输入 #1
5 3
输出 #1
15
P5703 【深基2.例5】苹果采购题解
#include<cstdio>
using namespace std;
int main(){
int a,b;
scanf("%d%d",&a,&b);
printf("%d",a*b);
return 0;
}
________________________________________________________
第七题 P5704 【深基2.例6】字母转换
题目描述
输入一个小写字母,输出其对应的大写字母。例如输入 q[回车] 时,会输出 Q。
输入格式
无
输出格式
无
输入输出样例
输入 #1
q
输出 #1
Q
P5704 【深基2.例6】字母转换题解
#include<iostream>
using namespace std;
int main(){
char a;
cin>>a;
a-=32;//在ASCLL表里的序列减去32
cout<<a;
return 0;
}
________________________________________________________
第八题 P5705 【深基2.例7】数字反转
题目描述
输入一个不小于 100 且小于 1000,同时包括小数点后一位的一个浮点数,例如 123.4,要求把这个数字翻转过来,变成 4.321 并输出。
输入格式
一行一个浮点数
输出格式
一行一个浮点数
输入输出样例
输入 #1
123.4
输出 #1
4.321
P5705 【深基2.例7】数字反转题解
#include <cstdio>
using namespace std;
int main(){
char a, b, c, d;
scanf("%c%c%c.%c", &a, &b, &c, &d);
printf("%c.%c%c%c", d, c, b, a);
return 0;
}
________________________________________________________
第九题 P5706 【深基2.例8】再分肥宅水
题目描述
现在有 t 毫升肥宅快乐水,要均分给 n 名同学。每名同学需要 2 个杯子。现在想知道每名同学可以获得多少毫升饮料(严格精确到小数点后 3 位),以及一共需要多少个杯子。
输入格式
输入一个实数 t 和一个正整数 n,使用空格隔开。
输出格式
输出两行。
第一行输出一个三位小数,表示可以获得多少毫升饮料。第二行输出一个正整数,表示一共需要多少个杯子。
输入输出样例
输入 #1
500.0 3
输出 #1
166.667 6
说明/提示
对于所有数据,0≤t≤10000 且小数点后不超过 3 位,1≤n≤1000。
P5706 【深基2.例8】再分肥宅水题解
#include<cstdio>
using namespace std;
int main(){
float a;
int b;
scanf("%f%d",&a,&b);
printf("%.3f\n%d",a/b,b*2);//保留三位小数输出
return 0;
}
________________________________________________________
第十题 P5708 【深基2.习2】三角形面积
题目描述
一个三角形的三边长分别是 a、b、c,那么它的面积为 ,其中 p=1/2(a+b+c)。输入这三个数字,计算三角形的面积,四舍五入精确到 11 位小数。
输入格式
第一行输入三个实数 a,b,c,以空格隔开。
输出格式
输出一个实数,表示三角形面积。精确到小数点后 11 位。
输入输出样例
输入 #1
3 4 5
输出 #1
6.0
说明/提示
数据保证能构成三角形,0≤a,b,c≤1000,每个边长输入时不超过 22 位小数。
P5708 【深基2.习2】三角形面积题解
#include<bits/stdc++.h>//万能头
using namespace std;
int main(){
double a,b,c,p;
cin>>a>>b>>c;//输入a,b,c
p=(a+b+c)/2;
printf("%.1f",sqrt(p*(p-a)*(p-b)*(p-c)));//sqrt是开根号
return 0;
}
________________________________________________________
第十一题 P5707 【深基2.例12】上学迟到
题目描述
学校和 yyy 的家之间的距离为 s 米,而 yyy 以 v 米每分钟的速度匀速走向学校。
在上学的路上,yyy 还要额外花费 10 分钟的时间进行垃圾分类。
学校要求必须在上午 8:00 到达,请计算在不迟到的前提下,yyy 最晚能什么时候出门。
由于路途遥远,yyy 可能不得不提前一点出发,但是提前的时间不会超过一天。
输入格式
一行两个正整数 s,v,分别代表路程和速度。
输出格式
输出一个 2424 小时制下的时间,代表 yyy 最晚的出发时间。
输出格式为 HH:MM,分别代表该时间的时和分。必须输出两位,不足前面补 00。
输入输出样例
输入 #1
100 99
输出 #1
07:48
说明/提示
对于 100% 的数据,1≤s,v≤104。
P5707 【深基2.例12】上学迟到题解
#include<bits/stdc++.h>
int main(){
int s, v, t, x, y;
scanf("%d%d",&s,&v);
t=1.0*s/v;//转换成浮点数 不然会只保留整数位
if(s%v!=0){t++;}
if((470-t)>=0){x=(470-t)/60;y=(470-t)%60;//470指的是最多要几分钟
if(y>=10){printf("0%d:%d",x,y);}
else{printf("0%d:0%d",x,y);}}
else{
x=23-(t-470)/60;y=60-(t-470)%60;
if(x<10){
if(y>=10){printf("%0d:%d",x,y);}
else{printf("%0d:0%d",x,y);}}
else{
if(y>=10){printf("%d:%d",x,y);}
else{printf("%d:0%d",x,y);}}}
return 0;}
________________________________________________________
第十二题 B2029 大象喝水
题目描述
一只大象口渴了,要喝 2020 升水才能解渴,但现在只有一个深 ℎh 厘米,底面半径为 r 厘米的小圆桶 (ℎh 和 r 都是整数)。问大象至少要喝多少桶水才会解渴。
Update:数据更新,这里我们近似地取圆周率 �=3.14π=3.14。
输入格式
输入有一行:包行两个整数,以一个空格分开,分别表示小圆桶的深 ℎh 和底面半径 r,单位都是厘米。
输出格式
输出一行,包含一个整数,表示大象至少要喝水的桶数。
输入输出样例
输入 #1
23 11
输出 #1
3
说明/提示 数据规模与约定
对于全部的测试点,保证 1≤h≤500,1≤r≤100。
B2029 大象喝水题解
#include<iostream>
using namespace std;
int main(){
int h,r;
cin>>h>>r;
printf("%.0lf",20000/(r*r*3.14*h)+1);
return 0;}
圆柱的体积公式
________________________________________________________
第十三题 P1425 小鱼的游泳时间
题目描述
伦敦奥运会要到了,小鱼在拼命练习游泳准备参加游泳比赛,可怜的小鱼并不知道鱼类是不能参加人类的奥运会的。
这一天,小鱼给自己的游泳时间做了精确的计时(本题中的计时都按 24 小时制计算),它发现自己从 a 时 b 分一直游泳到当天的 c 时 d 分,请你帮小鱼计算一下,它这天一共游了多少时间呢?
小鱼游的好辛苦呀,你可不要算错了哦。
输入格式
一行内输入四个整数,以空格隔开,分别表示题目中的 a,b,c,d。
输出格式
一行内输出两个整数 e 和 f,用空格间隔,依次表示小鱼这天一共游了多少小时多少分钟。其中表示分钟的整数 f 应该小于 60。
输入输出样例
输入 #1
12 50 19 10
输出 #1
6 20
P1425 小鱼的游泳时间题解
#include<iostream>
using namespace std;
int main(){
int a,b,c,d;
cin>>a>>b>>c>>d;
if(b<d){cout<<c-a<<" "<<d-b;}
else{cout<<c-a-1<<" "<<d+60-b;}
return 0;
}
___________________________________________________
第十四题 P1421 小玉买文具
题目描述
班主任给小玉一个任务,到文具店里买尽量多的签字笔。已知一只签字笔的价格是 1 元 9 角,而班主任给小玉的钱是 a 元 b 角,小玉想知道,她最多能买多少只签字笔呢。
输入格式
输入只有一行两个整数,分别表示 a 和 b。
输出格式
输出一行一个整数,表示小玉最多能买多少只签字笔。
输入输出样例
输入 #1
10 3
输出 #1
5
说明/提示 数据规模与约定
对于全部的测试点,保证 0≤a≤104,0≤b≤9。
P1421 小玉买文具题解
#include<bits/stdc++.h>
using namespace std;
int main(){
int a,b;
cin>>a>>b;
cout<<(a*10+b)/19;
return 0;}
________________________________________________________
第十五题 P3954 [NOIP2017 普及组] 成绩
题目背景
NOIP2017 普及组 T1
题目描述
牛牛最近学习了 C++ 入门课程,这门课程的总成绩计算方法是:
总成绩=作业成绩×20%+小测成绩×30%+期末考试成绩×50%
牛牛想知道,这门课程自己最终能得到多少分。
输入格式
三个非负整数 A,B,C,分别表示牛牛的作业成绩、小测成绩和期末考试成绩。相邻两个数之间用一个空格隔开,三项成绩满分都是 100 分。
输出格式
一个整数,即牛牛这门课程的总成绩,满分也是 100 分。
输入输出样例
输入 #1
100 100 80
输出 #1
90
输入 #2
60 90 80
输出 #2
79
说明/提示
样例 1 说明
牛牛的作业成绩是 100 分,小测成绩是 100 分,期末考试成绩是 80 分,总成绩是 100×20%+100×30%+80×50%=20+30+40=90
样例 2 说明
牛牛的作业成绩是 60 分,小测成绩是 90 分,期末考试成绩是 80 分,总成绩是 60×20%+90×30%+80×50%=12+27+40=79
数据说明
对于 30% 的数据,A=B=0。
对于另外 30% 的数据,A=B=100。
对于 100% 的数据,0≤A,B,C≤100 且 A,B,C 都是 10 的整数倍。
P3954 [NOIP2017 普及组] 成绩题解
#include<bits/stdc++.h>
using namespace std;
int main(){
int A,B,C;
cin>>A>>B>>C;
cout<<A/5+B*0.3+C/2;
return 0;
}
MVP结算:
本期字数:8543
本期质量分:97
30赞出下期 15赞换更Python 10赞出题解详细讲解