1.结构体数组存储学生信息(姓名,年龄,分数),完成输入学生信息,输出学生信息,求学生成绩之和,求最低学生成绩。
#include <myhead.h>
typedef struct
{
char name[20];
int age;
int score;
}stu;
int main(int argc, const char *argv[])
{
/*结构体数组存储学生信息(姓名,年龄,分数),完成输入学生信息,
输出学生信息,求学生成绩之和,求最低学生成绩。
*/
stu s[3];
int i;
for(i = 0;i<3;i++)
{
printf("请输入学生的信息:");
scanf("%s%d%d",s[i].name,&s[i].age,&s[i].score);
}
for(i = 0;i<3;i++)
{
printf("姓名:%s\t年龄%d\t成绩%d\n",s[i].name,s[i].age,s[i].score);
}
int sum=0;
for(i = 0;i<3;i++)
{
sum+= s[i].score;
}
printf("成绩之和为%d\n",sum);
int min,count = 0;
int sub;
for(i = 0;i<3;i++)
{
count++;
if(count == 1)
{
min = s[i].score;
}
if(s[i].score<=min)
{
min = s[i].score;
sub = i;
}
}
printf("最低成绩的学生是:\n");
printf("姓名:%s\t年龄:%d\t成绩:%d\n",s[sub].name,s[sub].age,s[sub].score);
return 0;
}
2.在堆区,申请5个结构体空间,存储学生信息(姓名,分数)循环输入学生信息,按照输入姓名查找某个学生,修改其成绩为100分。
#include <myhead.h>
typedef struct
{
char name[20];
int score;
}stu;
int main(int argc, const char *argv[])
{
/*在堆区,申请5个结构体空间,存储学生信息(姓名,分数)
循环输入学生信息,按照输入姓名查找某个学生,修改其成绩为100分。
*/
stu *p = malloc(sizeof(stu)*5);
int i;
for(i = 0;i<5;i++)
{
printf("请输入学生的信息:");
scanf("%s%d",(p+i)->name,&(p+i)->score);
}
for(i = 0;i<5;i++)
{
printf("姓名%s\t成绩%d\n",(p+i)->name,(p+i)->score);
}
int sub = -1;
char key[20];
printf("请输入要查找及修改的姓名:");
scanf("%s",key);
for(i = 0;i<5;i++)
{
if(strcmp((p+i)->name,key)==0)
{
sub = i;
}
}
if(sub == -1)
{
printf("查找失败\n");
}
else
{
printf("查找成功\n");
printf("姓名:%s\t成绩:%d\n",(p+sub)->name,(p+sub)->score);
}
(p+sub)->score = 100;
printf("已将其成绩改为100\n");
for(i = 0;i<5;i++)
{
printf("姓名%s\t成绩%d\n",(p+i)->name,(p+i)->score);
}
return 0;
}