2013-C++第13周班级对抗赛题目及参考解答

2023-10-15 00:40

本文主要是介绍2013-C++第13周班级对抗赛题目及参考解答,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759


Problem  A  她胖吗?

Description
奚嘉嘉是位爱美的女孩,身高165cm,体重52.5kg,可还是为保持身材错过了好多口福。实际上,保持健康和快乐,无论胖瘦都是美。当然太胖或太瘦可能对健康不利,适当注意即可。我们要为奚嘉嘉这样的爱美女孩设计一个程序,提供身体、体重,给出建议。女性的标准体重是:身高(厘米)-100= 标准体重(公斤),超过标准体重20%以上者为肥胖,低于标准体重20%的为偏瘦,在肥胖与偏瘦之间为正常。
Input
身高(cm)与体重(kg)值,身高整数,体重是小数
Output
肥胖时输出high,正常时输出normal,偏瘦要输出low。(注意全用小写)
Sample Input
165 52.5
Sample Output
normal
参考解答:
#include <iostream>
#include<cstdio>
#include <iomanip>
using namespace std;
int main()
{cin>>height>>weight;st = height - 100;if(weight/st>1.2)cout<<"high\n";else if((weight/st<0.8))cout<<"low\n";elsecout<<"normal\n";return 0;
}

Problem  B   股市风云

Description
股市强烈动荡,有涨有跌。现在有一组数据表示各公司的涨跌(涨为正,跌为负,不动为零),要求统计出平均涨幅和平均跌幅。
Input
一组数,其中有正数,也有负数,还有0。输入的个数不定,另外,不会出现只有正数或只有负数的情况。
Output
第一行输出见涨的数目和遇跌的数目;
第二行输出平均涨幅(正数的平均数)和平均跌幅(负数的平均数,再取反),保留小数点后3位。
Sample Input
5 0 -1 1.5 2.3 -0.3 2.4 0 7.9 -4.3
Sample Output
5 3
3.820 1.867
HINT
(1)用于处理不定数目的输入,参考:
int main()
{
    int a,b;
    while(cin >>a)
    {
        cout << a << endl;
    }
    return 0;
}
(2)输出x的值,保留两位小数,用:
cout<<setiosflags(ios::fixed)<<setprecision(3)<<x<<endl;
参考解答:(在调试时,最后一个数输完按CTRL_Z)
#include <iostream>
#include<cstdio>
#include <iomanip>
using namespace std;
int main()
{int c_inc=0, c_dec=0;  //涨的个数和跌的个数//freopen("input.txt","r",stdin);double v, s_inc=0, s_dec=0;  //用于涨跌值和用于求和的变量while(cin>>v){if(v>0){s_inc+=v;c_inc++;}else if(v<0){s_dec+=v;c_dec++;}}cout<<c_inc<<" "<<c_dec<<endl;cout<<setiosflags(ios::fixed)<<setprecision(3)<<(s_inc/c_inc)<<" "<<(-s_dec/c_dec)<<endl;return 0;
}

Problem  C   麦克劳林用于函数求值

Description
泰勒公式是一个用函数在某点的信息描述其附近取值的公式。如果函数足够光滑的话,在已知函数在某一点的各阶导数值的情况之下,泰勒公式可以用这些导数值做系数构建一个多项式来近似函数在这一点的邻域中的值。函数的麦克劳林展开是泰勒公式的特殊形式,即泰勒公式中“某一点”取0的情况。下面是e^x的麦克劳林展开式,据此求出多组e^x的值。
 
精度要求:最后一项大于1e-7
Input
输入一个整数N,代表输入数据的组数,后随N行,每行一个小数,分别代表一个x
Output
输出N行,分别代表各行x对应的ex的值。输出精确到小数点后第7位。
Sample Input
5
0
1
1.5
0.3
2.4
Sample Output
1.0000000
2.7182818
4.4816890
1.3498588
11.0231763
HINT
在C++中,cout<<setiosflags(ios::fixed)<<setprecision(7)<<y<<endl;输出的y值保留7位小数。
参考解答:
#include <iostream>
#include<cstdio>
#include <iomanip>
using namespace std;
int main( )
{int i, n, k;double x, ex, item;//freopen("input.txt","r",stdin);cin>>n;for(i=0; i<n; i++){cin>>x;ex=1;item=x;k=1;while(item>1e-7){ex+=item;k++;item=item*x/k;//cout<<item<<endl;}cout<<setiosflags(ios::fixed)<<setprecision(7)<<ex<<endl;}return 0;
}

Problem  D   我想有套北京的房

Description
小原是一个软件工程师,名叫原黛玛,他在北京工作。现在有一套房子,价格200万,房价每年上涨10%,每年固定能赚40万。他想知道要想买下这套房子,不贷款,不涨工资,没有其他收入,每年不吃不喝不消费,20年之内是否能攒够钱买下这套房子?
Input
房子的价格(万),房价上涨率,每年收入(万)。
Output
20年之内是否能买下房子的结论,能买下输出'Y',买不起输出'N'。
Sample Input
200 0.1 40
Sample Output
N
HINT
在调试过程中可以写一些输出语句观察计算过程,不过在最后提交前,将多余的输出删除。
参考解答:
#include <iostream>
#include<cstdio>
using namespace std;
int main( )
{double money;  //积蓄的钱double housePrice,rate, salary;  //房价、房价涨幅、年收入//freopen("input.txt","r",stdin); //重定向输入,从文件中读数据cin>>housePrice>>rate>>salary;money=salary;int year=1;while(year<=20 && money<housePrice){housePrice*=(1+rate);  //下一年房价money+=salary;       //下一年积蓄year++;}if(year>20)cout<<'N'<<endl;  //调试中,可以看看到底是否已经超出20年elsecout<<'Y'<<endl; //调试中,可以看看到底几年能买上return 0;
}

调试用的代码,加入了调试中可能需要对变量的观察(多余的输出要在OJ上提交删除):
#include <iostream>
#include<cstdio>
using namespace std;
int main( )
{double money;  //积蓄的钱double housePrice,rate, salary;  //房价、房价涨幅、年收入freopen("input.txt","r",stdin); //重定向输入,从文件中读数据cin>>housePrice>>rate>>salary;money=salary;int year=1;while(year<=20 && money<housePrice){cout<<"第"<<year<<"年,房子值 "<<housePrice<<"万,程序员有 "<<money<<"万元"<<endl;  //调试中输入这一行,可以看出变化趋势,当然提交时要删除或给这行语句加上注释housePrice*=(1+rate);  //下一年房价money+=salary;       //下一年积蓄year++;}if(year>20)cout<<year<<'N'<<endl;  //调试中,可以看看到底是否已经超出20年elsecout<<year<<'Y'<<endl; //调试中,可以看看到底几年能买上return 0;
}

Problem  E   北京买房方案辅助决策

Description
小原是一个软件工程师,名叫原黛玛,他在北京工作。现在有一套房子,价格200万,房价每年上涨10%,每年固定能赚40万。他想知道要想买下这套房子,不贷款,不涨工资,没有其他收入,每年不吃不喝不消费,20年之内是否能攒够钱买下这套房子?他还想知道,如果房子的价格、房价上涨率、每年收入可以有其他选择的话会如何。
Input
多行数据,每一行数据包括了一组房子的价格(万),房价上涨率,每年收入(万)。
Output
20年之内是否能买下房子的结论,能买下输出'Y',买不起输出'N'。针对每一组数据对应的输出,单独占一行。
Sample Input
200 0.05 40
200 0.1 40
100 0.8 200
1000 0.01 100
Sample Output
Y
N
Y
Y
HINT
在调试过程中可以写一些输出语句观察计算过程,不过在最后提交前,将多余的输出删除。
参考解答:
#include <iostream>
#include<cstdio>
using namespace std;
int main( )
{double money;  //积蓄的钱double housePrice,rate, salary;  //房价、房价涨幅、年收入//freopen("input.txt","r",stdin);while(cin>>housePrice>>rate>>salary){money=salary;int year=1;while(year<=20 && money<housePrice){housePrice*=(1+rate);  //下一年房价money+=salary;       //下一年积蓄year++;}if(year>20)cout<<'N'<<endl;elsecout<<'Y'<<endl;}return 0;
}

调试用的代码,加入了调试中可能需要对变量的观察(多余的输出要在OJ上提交删除):
#include <iostream>
#include<cstdio>
using namespace std;
int main( )
{double money;  //积蓄的钱double housePrice,rate, salary;  //房价、房价涨幅、年收入//freopen("input.txt","r",stdin); //重定向输入,从文件中读数据while(cin>>housePrice>>rate>>salary){money=salary;   int year=1;while(year<=20 && money<housePrice){cout<<"第"<<year<<"年,房子值 "<<housePrice<<"万,程序员有 "<<money<<"万元"<<endl;  //调试中输入这一行,可以看出变化趋势,当然提交时要删除或给这行语句加上注释housePrice*=(1+rate);  //下一年房价money+=salary;       //下一年积蓄year++;}if(year>20)cout<<year<<'N'<<endl;  //调试中,可以看看到底是否已经超出20年 elsecout<<year<<'Y'<<endl; //调试中,可以看看到底几年能买上}return 0;
}


==================== 迂者 贺利坚 CSDN博客专栏=================

|==  IT学子成长指导专栏  专栏文章分类目录(不定期更新)    ==|

|== C++ 课堂在线专栏   贺利坚课程教学链接(分课程年级)   ==|

======== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 =======



这篇关于2013-C++第13周班级对抗赛题目及参考解答的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214208

相关文章

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给