时间限制: 1 Sec 内存限制: 32 MB
定义一个结构体student,存储学生的学号、名字、性别和年龄,读入每个学生的所有信息,保存在结构体中,并输出。结构体student的定义如下:
struct student {
int num;
char name[20];
char sex;
int age;
};
本题要求使用指向结构体数组的指针进行输入和输出。
第一行有一个整数n,表示以下有n个学生的信息将会输入。保证n不大于20。
以后的n行中,每一行包含对应学生的学号、名字、性别和年龄,用空格隔开。保证每一个人名都不包含空格且长度不超过15,性别用M和F两个字符来表示。
有n行,每行输出一个学生的学号、名字、性别和年龄,用空格隔开。
请注意行尾输出换行。
3
10101 LiLin M 18
10102 ZhangFun M 19
10104 WangMin F 20
10101 LiLin M 18
10102 ZhangFun M 19
10104 WangMin F 20
#include
#include
using namespace std;
struct student {
int num;
char name[20];
char sex;
int age;
};
int main() {
int n;
cin >> n;
student s[20];
student *p=s;
for (int i = 0;i < n;i++) {
cin >> s[i].num >> s[i].name >> s[i].sex >> s[i].age;
}
for (int i = 0;i < n;i++) {
cout << (p + i)->num <<" "<< (p + i)->name << " " << (p + i)->sex << " " << (p + i)->age << endl;
}
}
时间限制: 1 Sec 内存限制: 32 MB
编写两个函数input和print,分别用来输入5个学生的数据记录和打印这5个学生的记录。对于每一个学生,其记录包含了学号、名字、3门课程的成绩共5项。用主函数分别调用input和print函数进行输入和输出。
要求使用结构体数组实现,结构体中包括了每个学生的5项记录。
共有5行,每行包含了一个学生的学号(整数)、名字(长度不超过19的无空格字符串)和3门课程的成绩(0至100之间的整数),用空格隔开。
与输入格式相同,每行输出一个学生的所有记录。
请注意行尾输出换行。
101 AAA 80 81 82
102 BBB 83 84 85
103 CCC 86 87 88
104 DDD 89 90 91
105 EEE 92 93 94
101 AAA 80 81 82
102 BBB 83 84 85
103 CCC 86 87 88
104 DDD 89 90 91
105 EEE 92 93 94
#include
using namespace std;
struct student {
int num;
char name[20];
double c1;
double c2;
double c3;
};
void input(student s[5]) {
for (int i = 0;i < 5;i++) {
cin >> s[i].num >> s[i].name >> s[i].c1 >> s[i].c2 >> s[i].c3;
}
}
void print(student s[5]) {
for (int i = 0;i < 5;i++) {
cout << s[i].num << " " << s[i].name << " " << s[i].c1 << " " << s[i].c2 << " " << s[i].c3 << endl;
}
}
int main() {
student s[5];
input(s);
print(s);
return 0;
}
时间限制: 1 Sec 内存限制: 32 MB
有10个学生,每个学生的数据包括学号、姓名、3门课程的成绩。读入这10个学生的数据,要求输出3门课程的总平均成绩,以及个人平均分最高的学生的数据(包括学号、姓名、3门课程成绩、平均分数)。
共有10行,每行包含了一个学生的学号(整数)、名字(长度不超过19的无空格字符串)和3门课程的成绩(0至100之间的整数),用空格隔开。
第一行包含了3个实数,分别表示3门课程的总平均成绩,保留2位小数,每个数之后输出一个空格。
第二行输出个人平均分最高的学生的数据,与输入数据格式相同。如果有多位个人平均分最高的学生,输出按照输入顺序第一个最高分的学生数据。
请注意行尾输出换行。
101 AAA 80 81 82
102 BBB 83 84 85
103 CCC 86 87 88
104 DDD 89 90 91
105 EEE 92 93 94
106 FFF 80 90 100
107 GGG 85 90 95
108 HHH 80 85 90
109 III 90 91 92
110 JJJ 91 88 87
85.60 87.90 90.40
105 EEE 92 93 94
#include
using namespace std;
struct student {
int num;
char name[20];
double c1;
double c2;
double c3;
};
int main() {
student s[10];
double a[10];
double c1sum=0, c2sum=0, c3sum=0;
for (int i = 0;i < 10;i++) {
cin >> s[i].num >> s[i].name >> s[i].c1 >> s[i].c2 >> s[i].c3;
c1sum += s[i].c1;
c2sum += s[i].c2;
c3sum += s[i].c3;
a[i] = (s[i].c1 + s[i].c2 + s[i].c3) / 3;
}
double max = a[0];
int t = 0;
for (int i = 1;i < 10;i++) {
if (a[i] > max) {
max = a[i];
t = i;
}
}
printf("%.2lf %.2lf %.2lf\n", c1sum / 10, c2sum / 10, c3sum / 10);
cout << s[t].num << " " << s[t].name << " " << s[t].c1 << " " << s[t].c2 << " " << s[t].c3;
}