2022秋季C语言专题实验08

8-1 平面向量加法

本题要求编写程序,计算两个二维平面向量的和向量。

输入格式:
输入在一行中按照“x1 y 1 x2 y2”的格式给出两个二维平面向量v1=(x1,y1)和v2=(x2,y2)的分量。

输出格式:
在一行中按照(x, y)的格式输出和向量,坐标输出小数点后一位(注意不能输出−0.0)。

输入样例:

3.5 -2.7 -13.9 8.7

输出样例:

(-10.4, 6.0)

代码实现:

#include <stdio.h>
int main()
{
    double x1, y1, x2, y2, x, y;
    scanf("%lf %lf %lf %lf", &x1, &y1, &x2, &y2);
    x = x1 + x2; y = y1 + y2;
    if (x > -0.05 && x < 0)
        x = 0;
    if (y > -0.05 && y < 0)
        y = 0;
    printf("(%.1lf, %.1lf)", x, y);
    return 0;
}

8-2 通讯录排序

输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。

输入格式:
输入第一行给出正整数n(<10)。随后n行,每行按照“姓名 生日 电话号码”的格式给出一位朋友的信息,其中“姓名”是长度不超过10的英文字母组成的字符串,“生日”是yyyymmdd格式的日期,“电话号码”是不超过17位的数字及+、-组成的字符串。

输出格式:
按照年龄从大到小输出朋友的信息,格式同输出。

输入样例:

3
zhang 19850403 13912345678
wang 19821020 +86-0571-88018448
qian 19840619 13609876543

输出样例:

wang 19821020 +86-0571-88018448
qian 19840619 13609876543
zhang 19850403 13912345678

代码实现:

#include<stdio.h>
struct ren
{
	char name[10];
	int year;
	char tel[17];
};
int main()
{
	int n;
	scanf("%d",&n);
	struct ren temp;
	struct ren fri[n];
	
	for(int i=0;i<n;i++)
	{
		scanf("%s %d %s",&fri[i].name,&fri[i].year,&fri[i].tel);
	}
	for(int i=0;i<n;i++)
	{
		for(int j=i+1;j<n;j++)
		{
			if(fri[i].year>fri[j].year)
			{
				temp=fri[i];
				fri[i]=fri[j];
				fri[j]=temp;
			 } 
		}
	}
	for(int i=0;i<n;i++)
	{
		printf("%s %d %s\n",fri[i].name,fri[i].year,fri[i].tel);
	}
	return 0;
}

8-3 计算平均成绩

给定N个学生的基本信息,包括学号(由5个数字组成的字符串)、姓名(长度小于10的不包含空白字符的非空字符串)和成绩([0,100]区间内的整数),要求计算他们的平均成绩,并顺序输出平均线以下的学生名单。

输入格式:
输入在一行中给出正整数N(≤10)。随后N行,每行给出一位学生的信息,格式为“学号 姓名 成绩”,中间以空格分隔。

输出格式:
首先在一行中输出平均成绩,保留2位小数。然后按照输入顺序,每行输出一位平均线以下的学生的姓名和学号,间隔一个空格。

输入样例:

5
00001 zhang 70
00002 wang 80
00003 qian 90
10001 li 100
21987 chen 60

输出样例:

80.00
zhang 00001
chen 21987

代码实现:

#include<stdio.h>
struct std{
        char name[10];
        char id[5];
        int score;
    };
int main(void){
    int n,i,sum=0;
    double average;
    scanf("%d",&n);
    struct std a[n];
    for(i=0;i<n;i++){
        scanf("%s%s%d",a[i].id,a[i].name,&a[i].score);
    }
    for(i=0;i<n;i++){
        sum+=a[i].score;
    }
    average=sum/n*1.0;
    printf("%0.2f\n",average);
    for(i=0;i<n;i++){
        if(a[i].score<average){
            printf("%s %s\n",a[i].name,a[i].id);
        }
    }
    return 0;
}

8-4 学分统计

已知某大学校选课成绩选用四级制,分别为A、B、C、D,其中A、B、C级获得学分,D级没有学分。规定学业成绩大于等于85的为A级,70-84的评为B级,60-69的评为C级,60分以下的评为D级,请你写一个程序将得分转换为等级,并统计没有获得学分的人数。

输入格式:
输入第一行为一个正整数n(n<=10),代表选课学生人数,随后n行,每行为一个学生信息,包括学号(长度为12的不带空格的数字串)、姓名(长度不超过20的不带空格的一串字符)、得分(大于等于0且小于等于100的整数)。

输出格式:
按照输入顺序输出所有选课学生的最终成绩等级信息,一个选课学生信息占一行,包括学号、姓名、成绩等级,中间用一个空格分隔,随后一行输出没有获得学分的人数。

输入样例:

2
201001010101 li 85
201200000101 zhang 59

输出样例:

201001010101 li A
201200000101 zhang D
1

代码实现:

#include<stdio.h>
struct stu{
    char sno[13];
    char sname[21];
    int score;
};
int main()
{
    int n;
    scanf("%d",&n);
    struct stu a[n];
    int cnt = 0;
    for(int i=0;i<n;i++){
        scanf("%s %s %d",a[i].sno,a[i].sname,&a[i].score);
        if(a[i].score >= 85)
            printf("%s %s A\n",a[i].sno,a[i].sname);
        else if(a[i].score >= 70)
            printf("%s %s B\n",a[i].sno,a[i].sname);
        else if(a[i].score >= 60)
            printf("%s %s C\n",a[i].sno,a[i].sname);
        else {
            printf("%s %s D\n",a[i].sno,a[i].sname);
            cnt++;
        }
    }
    printf("%d",cnt);
    return 0;
}

8-5 游戏玩家

某游戏公司年末推出一款新游戏,共设置100层关卡,邀请游戏玩家们内测,根据到达关卡层级对玩家授予不同称号,并对获得神级玩家称号的玩家进行奖励,赠送高级游戏装备一套。已知到达关卡90-100的玩家授予神级玩家称号(S),到达关卡80-89的玩家授予牛级玩家称号(N),达到关卡70-79的玩家授予高级玩家称号(G),到达70以下关卡的授予普通玩家称号(C)。请你帮助该公司记录玩家称号,并统计能够获得高级游戏装备的玩家人数。

输入格式:
输入为2行,第一行为一个正整数n(n<=10),代表玩家人数,随后n行,每行为一个玩家信息,包括玩家ID(长度为9的不带空格的数字串)、昵称(长度不超过20的不带空格的一串字符)、到达关卡层级数(大于等于0的整数且小于等于100的整数)。

输出格式:
按照输入顺序输出所有玩家的等级信息,一个玩家信息占一行,包括玩家ID、昵称、称号,中间用一个空格分隔,随后一行输出能够获赠高级游戏装备的人数。

输入样例:

2
000001 li 90
000002 zhang 79

输出样例:

000001 li S
000002 zhang G
1

代码实现:

#include<stdio.h>
struct player
{ char name[30];
  char ID[20];
  int flag;
}p[13];
 
int main()
{
 int n,i,cnt=0;
 scanf("%d",&n);
 for(i=0;i<n;i++)
  {
    scanf("%s %s %d",p[i].ID,p[i].name,&p[i].flag);
    if((p[i].flag>=90)&&(p[i].flag<=100))
    cnt++;
  }
  for (i=0; i<n; i++)
  { 
    if((p[i].flag>=90)&&(p[i].flag<=100))
    printf("%s %s S\n",p[i].ID,p[i].name);
    else if((p[i].flag>=80)&&(p[i].flag<=89))
    printf("%s %s N\n",p[i].ID,p[i].name);
    else if((p[i].flag>=70)&&(p[i].flag<=79))
    printf("%s %s G\n",p[i].ID,p[i].name);
    else
    printf("%s %s C\n",p[i].ID,p[i].name);
 
  }
  printf("%d",cnt);
  return 0;
}

谢谢浏览!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值