习题一:KiKi定义电子日历类
描述
KiKi学习了面向对象技术,学会了通过封装属性(变量)和行为(函数)定义类,现在他要设计一个电子日历类TDate。
它有3个私有数据成员:Month,Day,Year和若干个公有成员函数,要求:
(1)带有默认形参值的构造函数,默认值为0, 0, 0;
(2)输出日期函数,用“日/月/年”格式输出日期;
(3)设置日期函数,从键盘输入年、月、日。
输入描述
- 一行,三个整数,用空格分隔,分别表示年、月、日。
输出描述
- 一行,用“日/月/年”格式输出日期。
示例
输入: 2019 12 30 输出: 30/12/2019
代码实现
#include<iostream> #include<string> using namespace std; class TDate { public: TDate(int a=0,int b=0,int c=0)//默认形参,默认值0,0,0 { Month=a; Day=b; Year=c; cout<<Day<<"/"<<Month<<"/"<<Year<<endl;//输出格式 } private: int Month,Day,Year;//三个私有数据成员 }; int main() { int a,b,c; cin>>a>>b>>c; TDate t(b,c,a);//带入构造函数 return 0; }
习题二:KiKi设计类继承
描述
KiKi理解了继承可以让代码重用,他现在定义一个基类shape,私有数据为坐标点x,y, 由它派生Rectangle类和Circle类,它们都有成员函数GetArea()求面积。派生类Rectangle类有数据:矩形的长和宽;派生类Circle类有数据:圆的半径。Rectangle类又派生正方形Square类,定义各类并测试。输入三组数据,分别是矩形的长和宽、圆的半径、正方形的边长,输出三组数据,分别是矩形、圆、正方形的面积。圆周率按3.14计算。
输入描述
- 输入三行,
- 第一行为矩形的长和宽,
- 第二行为圆的半径,
- 第三行为正方形的边长。
输出描述
- 三行,分别是矩形、圆、正方形的面积。
示例1
输入: 7 8 10 5 输出: 56 314 25
代码实现
**示例2** ```c 输入: 3 3 2 1 输出: 2 1 3
习题三:牛牛的书
描述
- 牛牛正在买书,每本书都有名字和价格,牛牛想把书按照价格升序排序。
输入描述
- 第一行输入一个正整数 n ,表示书的数量。
- 后续每行都输入一个字符串 str 和一个正整数 p 表示书价格。
输出描述
- 把书名按照价格升序输出。
示例
输入: 3 TheNowcoder 100 Abook 20 BBook 300 输出: Abook TheNowcoder BBook
代码实现
#include <stdio.h> //#include <stdlib.h>应该是要加上的,没加也过了 typedef struct Book{ char name[100]; int price; }BOOK; int cmp_by_price(const void*e1,const void*e2) { return ((BOOK *)e1)->price-((BOOK *)e2)->price; } int main() { int n = 0; scanf("%d",&n); BOOK arr[n]; for (int i = 0;i < n;i++) { scanf("%s %d",&arr[i].name,&arr[i].price); } int sz = sizeof(arr)/sizeof(arr[0]); qsort(arr,sz,sizeof(arr[0]),cmp_by_price);//快排 for(int i = 0;i < n;i++) { printf("%s\n",arr[i].name); } return 0; }
习题四:牛牛的平面向量
描述
- 牛牛有 n 个平面向量 (x1,y1) ,牛牛把这几个向量相加并输出这个向量的值。
输入描述
- 第一行输入一个正整数 n
- 后续 n 行每行输入两个正整数分别是 x 和 y。
输出描述
- 输出所有的向量相加的结果
示例
输入: 3 1 2 2 1 3 3 输出: 6 6
代码实现
#include<stdio.h> int main() { //没用上结构体的知识点 int n,x=0,y=0,sumX=0,sumY=0; scanf("%d",&n); for(int i=0;i<n;i++){ scanf("%d %d",&x,&y); sumX+=x; sumY+=y; } printf("%d %d",sumX,sumY); return 0; return 0; }
习题五:牛牛的时钟
描述
- 牛牛在午夜12点(0点0分0秒)正在思考,在 t 秒之后是什么时间。他思考了 n 次这个问题。
输入描述
- 第一行输入一个正整数 n。
- 第二行输入 n 个正整数 t ,表示 t 秒之后。
输出描述
- 输出 n 行,每行输出 t 秒之后的时间。
示例1
输入: 4 60 61 1 2 输出: 0 1 0 0 2 1 0 2 2 0 2 4
代码实现
#include<stdio.h> int main() { int n, a,b=0; scanf("%d",&n); for(int i=0;i<n;i++) { scanf("%d",&a); b=a+b;//这里是求每次思考后的总时间 printf("%d %d %d\n",b/3600,(b%3600)/60,b%60); } return 0; }