LHL MOOC 计算机程序设计(C++)2020 期末考试 课程考试——编程题

1成绩统计(15分)
题目内容:

输入若干学生的成绩,统计各班的成绩的平均值,并按班级名称的机内码从小到大排序输出。

学生成绩信息包括:班级,学号和成绩。班级名称是"000"'时表示成绩输入结束。

班级名称不超过20字符,学号不超过10个字符,成绩为整数,平均成绩为双精度实数,保留三位小数。班级数不超过10个,总人数不超过100个。

输入格式:

若干行,每行信息包括班级,学号和成绩,用空格隔开,

最后一行为:000 000 000

输出格式:

若干行,每行信息包括:班级和平均成绩,中间用一个空格隔开。行数由输入中的班级数确定。

输入样例:

航天 001 80

信计 001 90

航天 002 70

航天 003 80

信计 002 91

000 000 000

输出样例:

航天 76.667

信计 90.500

时间限制:500ms内存限制:32000kb

#include
#include
#include
using namespace std;
struct peo{
     
char name[21];
int sum;//总分数
int ss;//人数
}S2[11];
int main()
{
     
    char name[21],num[11];
    int score;
    int j=0,t=0,i,temp=0;
   while(1)
   {
     
        cin>>name>>num>>score;
        temp=0;//是否找到的标记
        if (strcmp(name,"000")==0)
            break;
        for (i=0;i<j;i++)
        {
     
            if (strcmp(S2[i].name,name)==0)//如果当前输入在结构体数组中找到,则将分数加入sum
           {
     
              S2[i].sum+=score;
              S2[i].ss++;
              temp=1;
           }
        }
            if (temp==0)//如果没找到,则创建当前含有name的结构体
           {
     
           strcpy(S2[j].name,name);
           S2[j].sum+=score;
           S2[j].ss++;
           j+=1;
        }
   }
    for (i=0;i<j;i++)//排序
    {
     
        for (t=0;t<j-i-1;t++)
        {
     
            if (strcmp(S2[t].name,S2[t+1].name)>0)
            {
     

                struct peo tt;
                tt=S2[t];
                S2[t]=S2[t+1];
                S2[t+1]=tt;
            }
        }
    }
    for (i=0;i<j;i++)
    {
     
        cout<<S2[i].name<<' ';
        printf("%.3f\n",1.0*S2[i].sum/S2[i].ss);
    }
    return 0;
}

2时间类(10分)
定义时间类,私有成员时、分、秒,整型;成员函数:set()设置时间,add()加时间,show()显示时间。编写主函数,定义时间类对象,用户输入时间的时、分、秒,设置对象的时间为用户输入的时、分、秒,用户再输入时间(表示时间长度),计算第1个之间加第2个时长后的时间,格式为hh:mm:ss,24小时制,最小时刻为00:00:00,最大时刻为23:59:59。

输入:两行,每行三个整数,第一行为某时刻,第2行为某时长的时、分、秒。

输出:两行,加之前的时刻,加之后的时刻。

【输入输出样例】
输入:

8 59 59

0 0 2

输出:

08:59:59

09:00:01

#include
using namespace std;
class MyTime
{
     
private:
int hour, minute, second;
public:
 MyTime(){
      hour = 0; minute = 0; second = 0; }
 MyTime(int, int, int);
 void print_12();
 void print_24();
 void set_time(int, int, int);
 MyTime add(int,int,int);
 MyTime subtract(int, int, int);
};
MyTime::MyTime(int a, int b, int c)
{
     
 hour = (a >= 0 && a <= 23) ? a : 0;
 minute = (b >= 0 && b <= 59) ? b : 0;
 second = (c >= 0 && c <= 59) ? c : 0;
}
void MyTime::print_12()
{
     
 if (hour < 12)
 {
     
  printf("%02d:%02d:%02d AM", hour, minute, second); 
 }
 else
 {
     
  printf("%02d:%02d:%02d PM", hour-12, minute, second);
 }
 cout << endl;
}
void MyTime::print_24()
{
     
 printf("%02d:%02d:%02d", hour, minute, second);
 cout << endl;
}
void MyTime::set_time(int a, int b, int c)
{
     
 hour = (a >= 0 && a <= 23) ? a : 0;
 minute = (b >= 0 && b <= 59) ? b : 0;
 second = (c >= 0 && c <= 59) ? c : 0;
}
MyTime MyTime::add(int a,int b,int c)
{
     
 MyTime t0=*this;
 t0.hour = hour + a;
 t0.minute = minute + b;
 t0.second = second + c;
 if (t0.second >= 60)
 {
     
  t0.second -= 60;
  t0.minute++;
 }
 if (t0.minute >= 60)
 {
     
  t0.minute -= 60;
  t0.hour++;
 }
 if (t0.hour >= 24)
 {
     
  t0.hour -= 24;
 }
 return t0;
}
MyTime MyTime::subtract(int a, int b, int c)
{
     
 MyTime t0 = *this;
 t0.hour = hour - a;
 t0.minute = minute - b;
 t0.second = second - c;
 if (t0.second < 0)
 {
     
  t0.second += 60;
  t0.minute--;
 }
 if (t0.minute < 0)
 {
     
  t0.minute += 60;
  t0.hour--;
 }
 if (t0.hour < 0)
 {
     
  t0.hour += 24;
 }
 return t0;
}
int main()
{
     
 MyTime t1,t2,t3,t4;
 int a, b, c;
 cin >> a >> b >> c;
 t1.set_time(a, b, c);
 cin >> a >> b >> c;//待加减的时间
 t3 = t1.add(a, b, c);//t1加输入时间
 t1.print_24();t3.print_24();
 return 0;
}

LHL MOOC 计算机程序设计(C++)2020 期末考试 课程考试——编程题_第1张图片

#include
using namespace std;
#include

void addone(vector<int>& arr)//6进制数加1 
{
     
	int index = 0;
	while(true)
	{
     
		if(arr.size() == index)
		{
     
			arr.push_back(1);
			break;
		}
		else
		{
     
			arr[index]++;
			if(arr[index] == 6)//逢6进1;
			{
     
				arr[index] = 1;
				index++;
			}
			else
			{
     
				break;//不进1,退出循环 
			}
		}
	}
}

int main()
{
     	
	int num;//10进制数字 
	vector<int> arr;//保存6进制数字的数组,下标越大,位数越大。 
	
	cin >> num;//输入 
	
	for(int i = 0; i < num; i++)
	{
     
		addone(arr);//6进制数加一 
	}
	
	//输出 
	for(int j = arr.size()-1; j >= 0; j--)
	{
     
		cout << (char)(arr[j]+64);
	}
	cout << endl;
	
	return 0;
}

你可能感兴趣的:(LHL'PTA,c++,算法,数据结构)