【XDOJ】结构体实战练习

【XDOJ】结构体实战练习

一.基础题型

成绩统计

有N(0<N<=100)个学生,每个学生有3门课的成绩,输入每个学生数据(包括学号,姓名,三门课成绩),计算每个学生的平均成绩,并按照平均成绩从高到低的顺序输出学生信息,平均成绩相同时,则按照学号从小到大顺序输出。

#include <stdio.h>

struct student
{
	int number;
	char name[10];
	float a,b,c,d;
};//定义结构体类型 注意-';' 
int main()
{
	int n;
	scanf("%d",&n);//输入学生个数 
	struct student per[n],t;//结构体变量初始化 注意-'t'是结构体变量,用于后续交换结构体 
	int i,j;
	for(i=0;i<n;i++)
	{
		scanf("%d %s %f %f %f",&per[i].number,per[i].name,&per[i].a,&per[i].b,&per[i].c);//输入变量成员内容 
	per[i].d=(per[i].a+per[i].b+per[i].c)/3;//计算平均成绩 
	}
	for(i=0;i<n-1;i++)
	{
		for(j=0;j<n-1-i;j++)
		{
			if(per[j].d<per[j+1].d)
			{
				t=per[j];
				per[j]=per[j+1];
				per[j+1]=t;
			}//平均成绩降序排序 
			else if(per[j].d==per[j+1].d)
			{
				if(per[j].number>per[j+1].number)
				{
					t=per[j];
				    per[j]=per[j+1];
				    per[j+1]=t;
				}
			}//平均成绩相同时,按照学号升序排序
		}
	}//冒泡排序 
	for(i=0;i<n;i++)
	{
		printf("%d %s %.1f\n",per[i].number,per[i].name,per[i].d);//输出结果 
	}
}

二.进阶题型

年月日统计

定义一个结构体变量(包括年,月,日)。计算该日在本年中是第几天,(注意闰年问题)

#include <stdio.h>

struct num
{
	int year,month,day,date;
};//定义结构体类型 
int main()
{ 
	struct num n;//结构体变量初始化 
	int mon[12]={0,31,28,31,30,31,30,31,31,30,31,30};//七月大,八月大 
	scanf("%d,%d,%d",&n.year,&n.month,&n.day);
	n.date=n.day;
	if((n.year%4==0&&n.year%100!=0)||n.year%400==0)//闰年-年份能被四整除且不能被100整除,或可被400整除 
	mon[2]=29;//数组元素修改 
	int i;
	for(i=n.month-1;i>=0;i--)//注意此处的循环 
	n.date+=mon[i];
	printf("%d",n.date);
}

排球比赛

int main()
{
	int n,i,j;
	scanf("%d",&n);//输入队伍数 
	struct team per[n],t;
    for(i=0;i<n;i++)
    scanf("%s",&per[i].name);//输入队伍名称 
	for(i=0;i<n;i++)
    {
    	for(j=0;j<n;j++)
    	{
    		scanf("%d",&per[i].score[j]);
		}
	}//输入比赛结果 
	for(i=0;i<n;i++)
	{
		per[i].win=0;
		per[i].point=0;
	}//胜场数,积分置0 
	for(i=0;i<n;i++)
    {
    	for(j=0;j<n;j++)
    	{
    		if(per[i].score[j]>0)
    		per[i].win++;
    		if(per[i].score[j]==5)
    		per[i].point+=2;
    		if(per[i].score[j]==4||per[i].score[j]==3)
    		per[i].point+=3;
    		if(per[i].score[j]==-5)
    		per[i].point++;
		}
	}//遍历矩阵,计算胜场数和积分 
	for(i=0;i<n-1;i++)
	{
		for(j=i+1;j<n;j++)//细节i,j 
		{
			if(per[i].win<per[j].win)
			{
				t=per[i];
				per[i]=per[j];
				per[j]=t;
			}
			else if(per[i].win==per[j].win)
			{
				if(per[i].point<per[j].point)
				{
					t=per[i];
				    per[i]=per[j];
				    per[j]=t;
				}
				else if(per[i].point==per[j].point)
				{
					if(strcmp(per[i].name,per[j].name)>0)
					{
						t=per[i];
				        per[i]=per[j];
				        per[j]=t;
					}
				}
			}
		}
	}//排序 
	for(i=0;i<n;i++)
	printf("%s %d %d\n",per[i].name,per[i].win,per[i].point);//细节i,j 
}

tips

注意在循环中的相关计算

for(i=0;i<n;i++)
	{
	scanf("%s %c %f %f %f %f",per[i].name,&per[i].gender,&per[i].a,&per[i].b,&per[i].c,&per[i].d);
	per[i].e=per[i].a+per[i].b+per[i].c+per[i].d;//[i] 
    }//括号 

三.终级打怪

补充:结构体做函数参数

注意区分实参和形参
结构体数组/结构体指针

网费缴纳

输入上网信息,按照计费标准,计算并输出网费信息(函数输入信息和进行计算)

#include <stdio.h>

struct internet
{
	char name[20];
	int num;
	float start,stop,cost;
}
void in(struct internet a[],int N)//a[]部分也可写为*p-用指针传参 
{
	int i;
	for(i=0;i<N;i++)
	{
		scanf("%s %d %f %f",a[i].name,&a[i].num,&a[i].start,&a[i].stop);
	}
}
//其余部分省略 
int main()
{
	int N;
	scanf("%d",&N);
	stuct internet network[N];
	in(network,N);
}
  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值