PTA第十章题目集合

2-1
The value of expression *((int *)(p+1)+2) is D.

static struct {
    int x, y[3];
} a[3] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}}, *p;
p = a+1;

(2分)
A.3
B.7
C.10
D.11

实现代码:

#include <stdio.h>
#include <stdlib.h>
#include<string.h>

	static struct {
    int x, y[3];
} a[3] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}}, *p;

int main()
{

p = a+1;

int i=0;
i = *((int *)(p+1)+2);
printf("%d",i);
	
	return 0;
	
}

2-4
如果有以下定义语句,则输出结果为(B)。

struct {
      int x, y;
} s[2] = { { 1, 3 }, { 2, 7 } };
printf(%d\n”, s[0].y/s[1].x );

(2分)

A.0
B.1
C.2
D.3

**

6-1 计算两个复数之积

**
本题要求实现一个计算复数之积的简单函数。

函数接口定义:

struct complex multiply(struct complex x, struct complex y);

其中struct complex是复数结构体,其定义如下:

struct complex{
    int real;
    int imag;
};

裁判测试程序样例:

#include <stdio.h>

struct complex{
    int real;
    int imag;
};

struct complex multiply(struct complex x, struct complex y);

int main()
{
    struct complex product, x, y;

    scanf("%d%d%d%d", &x.real, &x.imag, &y.real, &y.imag);
    product = multiply(x, y);
    printf("(%d+%di) * (%d+%di) = %d + %di\n", 
            x.real, x.imag, y.real, y.imag, product.real, product.imag);

    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

3 4 5 6

输出样例:

(3+4i) * (5+6i) = -9 + 38i

示例:

struct complex multiply(struct complex x, struct complex y)
{ 
  struct complex product;//再次声明一下
  product.real=x.real*y.real-x.imag*y.imag;
  product.imag=x.imag*y.real+y.imag*x.real;
  return product;
}

//结构体的嵌套

**

6-2 按等级统计学生成绩

**
本题要求实现一个根据学生成绩设置其等级,并统计不及格人数的简单函数。

函数接口定义:

int set_grade( struct student *p, int n );

其中p是指向学生信息的结构体数组的指针,该结构体的定义为:

struct student{
    int num;
    char name[20];
    int score;
    char grade;
};

n是数组元素个数。学号num、姓名name和成绩score均是已经存储好的。set_grade函数需要根据学生的成绩score设置其等级grade。等级设置:85-100为A,70-84为B,60-69为C,0-59为D。同时,set_grade还需要返回不及格的人数。

裁判测试程序样例:

#include <stdio.h>
#define MAXN 10

struct student{
    int num;
    char name[20];
    int score;
    char grade;
};

int set_grade( struct student *p, int n );

int main()
{   struct student stu[MAXN], *ptr;
    int n, i, count;

    ptr = stu;
    scanf("%d\n", &n);
    for(i = 0; i < n; i++){
       scanf("%d%s%d", &stu[i].num, stu[i].name, &stu[i].score);
    } 
   count = set_grade(ptr, n);
   printf("The count for failed (<60): %d\n", count);
   printf("The grades:\n"); 
   for(i = 0; i < n; i++)
       printf("%d %s %c\n", stu[i].num, stu[i].name, stu[i].grade);
    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

10
31001 annie 85
31002 bonny 75
31003 carol 70
31004 dan 84
31005 susan 90
31006 paul 69
31007 pam 60
31008 apple 50
31009 nancy 100
31010 bob 78

输出样例:

The count for failed (<60): 1
The grades:
31001 annie A
31002 bonny B
31003 carol B
31004 dan B
31005 susan A
31006 paul C
31007 pam C
31008 apple D
31009 nancy A
31010 bob B

示例:

int set_grade( struct student *p, int n )
{
    int count=0,i;  //初始化不及格人数

    for(i=0;i<n;i++)
    {
        if((*p).score<60)  //即stu[i].score
        {
            (*p).grade='D';
            count++;
        }

        else if((*p).score>=60&&(*p).score<=69)
        (*p).grade='C';

        else if((*p).score>=70&&(*p).score<=84)
        (*p).grade='B';

        else
        (*p).grade='A';

		p++; //逐个给学生评级
    }

    return count;
}

加粗样式斜体样式
删除线格式

6-3 输出结构体数组中年龄最大者的数据

给定程序中,函数fun的功能是:将形参std所指结构体数组中年龄最大者的数据作为函数值返回,并在主函数中输出。

函数接口定义:

struct student fun(struct student  std[], int  n);

其中 std 和 n 都是用户传入的参数。 函数fun的功能是将含有 n 个人的形参 std 所指结构体数组中年龄最大者的数据作为函数值返回。

裁判测试程序样例:

#include <stdio.h>

struct student
{char  name[10];
 int  age;
};
struct student fun(struct student  std[], int  n);
int main()
{
struct student std[5]={"aaa",17,"bbb",16,"ccc",18,"ddd",17,"eee",15  };
struct student  max;
max=fun(std,5);
printf("\nThe result:\n");
printf("\nName : %s,   Age :  %d\n", max.name,max.age);
return 0;
 }


/* 请在这里填写答案 */

输出样例:

The result:

Name : ccc,   Age :  18

示例:

struct student fun(struct student std[], int n)
{
    int i,max = 0;
    int k;//计数

    for(i=0;i<5;i++)
  {
      if(std[i].age>max)
         {
             max = std[i].age;
             k = i;
         }
  }

    return std[k];//返回部分结构体的写法
}

删除线格式 删除线格式 删除线格式 删除线格式

**

6-4 结构体数组按总分排序

**
有一组学生数据,每个数据中含有三门课成绩,请按成绩总和从高到低对这组数据进行排序。 编写函数calc求出每名学生的总分。 编写函数sort按每名学生的总分从高到低对这组数据进行排序

函数接口定义:

void calc(struct student *p,int n);     
void sort(struct student *p,int n);

其中 p 和 n 都是用户传入的参数。 函数calc求出p指针所指的结构体数组中 n 名学生各自的总分。 函数sort对p指针所指的结构体数组的学生数据按总分降序排序。

裁判测试程序样例:

#include <stdio.h>
struct student                    
{
int num;
char name[15];
float score[3];
float sum;
};
void calc(struct student *p,int n);     
void sort(struct student *p,int n);
int main()
{
struct student stu[5];
int i,j;
float f;
for(i=0;i<5;i++)
{
    scanf("%d%s",&stu[i].num,stu[i].name);
    for(j=0;j<3;j++)
    { 
        scanf("%f",&f);
        stu[i].score[j]=f;
    }
}
calc(stu,5);
sort(stu,5);
for(i=0;i<5;i++)
{
    printf("%5d%15s",stu[i].num,stu[i].name);
    printf("  %.1f  %.1f  %.1f  %.1f\n",stu[i].score[0],stu[i].score[1],stu[i].score[2], stu[i].sum);
}
return 0;


/* 请在这里填写答案 */

输入样例:

1 zhang 89 87 85
2 liu  92 98 96
3 li 74 71 72
4 xion 95 98 99
5 liu 99 100 100

输出样例:

  5            liu  99.0  100.0  100.0  299.0
    4           xion  95.0  98.0  99.0  292.0
    2            liu  92.0  98.0  96.0  286.0
    1          zhang  89.0  87.0  85.0  261.0
    3             li  74.0  71.0  72.0  217.0

示例:

//用指针操作的另一种数组写法

void calc(struct student *p,int n)
{
    int i;
    for(i=0;i<n;i++)
    {
        p[i].sum=p[i].score[0]+p[i].score[1]+p[i].score[2];
    }
}


void sort(struct student *p,int n)
{
    struct student std;
    int i,j,k;
    float max;
    
    for(i=0;i<n;i++)
    {
        max=0;
        
        for(j=i;j<n;j++)
        {
            if(max<p[j].sum)
            {
                max=p[j].sum;
                k=j;
            }
        }
        
        std=p[i];
        p[i]=p[k];
        p[k]=std;
    }

}

删除线格式 删除线格式 删除线格式 删除线格式

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

懒回顾,半缘君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值