计算机科学-第4周 结构 题目及参考解答

《计算机科学》课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597

  例1: 用一个结构表示点,输入点的横纵坐标,输出该点到原点的距离

#include <stdio.h>
#include <math.h>
struct Point
{
    float x;
    float y;
};
int main()
{
    struct Point p;
    float d;
    printf("请输入点的坐标: ");
    scanf("%f %f",&p.x, &p.y);
    d = sqrt(p.x*p.x+p.y*p.y);
    printf("两点间的距离是: %f", d);
    return 0;
}

  练习1:定义点结构,求两点之间的距离,及对称点,运行结果如下图:
  
  参考解答:

#include <stdio.h>
#include <math.h>
struct Point
{
    float x;
    float y;
};
int main()
{
    struct Point p1, p2;
    float dx,dy,d;
    printf("请输入p1点的坐标: ");
    scanf("%f %f",&p1.x, &p1.y);
    printf("请输入p2点的坐标: ");
    scanf("%f %f",&p2.x, &p2.y);
    dx=p1.x-p2.x;
    dy=p1.y-p2.y;
    d = sqrt(dx*dx+dy*dy);
    printf("两点间的距离是: %.2f\n", d);
    printf("p1关于x轴的对称点是(%.1f, %.1f)\n", p1.x, -p1.y);
    printf("p2关于原点的对称点是(%.1f, %.1f)\n", -p2.x, -p2.y);
    return 0;
}

  例2:下面的程序,利用结构数组,输入了学生学号和两门课的成绩,计算均分后,输出了成绩单:

#include <stdio.h>
#define N 100
struct Student
{
   int num; //学号
   int c; //C语言成绩
   int law; //法律成绩
   float aver;  //两科均分
};
int main( )
{
   int i;
   //定义结构体数组存放多名同学的成绩
   struct Student stu[N];
   printf("请输入学号、C和法律课的成绩: \n");
   for(i=0;i<N;i++)
   {
       scanf("%d %d %d",&stu[i].num,&stu[i].c, &stu[i].law);
       stu[i].aver=(stu[i].c+stu[i].law)/2.0;
   }
   //输出成绩单
   printf("学号\tC\t法律\t均分\n");
   for(i=0;i<N;i++)
       printf("%d\t%d\t%d\t%.2f\n",stu[i].num, stu[i].c,stu[i].law, stu[i].aver);
   return 0;
}

  练习2:请在上面的程序的基础上增加功能,使运行结果如下图:
  
  其中,需要做出的改动是:
  (1)计算每名学生的学分绩——各科成绩乘以学分的和,再除以总学分(本题中,C语言和法律课的学分分别是3和4);
  (2)计算各科的均分;
  (3)输出得奖学金的同学学号清单——奖学金规则是,学分绩要高于80且没有挂科。

参考解答:

#include <stdio.h>
#define N 5
struct Student
{
    int num; //学号
    int c; //C语言成绩,学分为3
    int law; //法律成绩,学分为4
    float aver;  //平均学分绩(各科成绩乘以学分的和,再除以总学分)
};
int main( )
{
    int i;
    //freopen("input.txt","r",stdin);
    int totalC=0, totalLaw=0;
    float averC, averLaw;
    struct Student stu[N];//定义结构体数组存放多名同学的成绩
    printf("请输入学号、C和法律课的成绩: \n");
    //输入成绩,并求出平均学分绩
    for(i=0; i<N; i++)
    {
        scanf("%d %d %d",&stu[i].num, &stu[i].c, &stu[i].law);
        stu[i].aver=(stu[i].c*3+stu[i].law*4)/7.0;
    }
    //求各科的总分,目的是求出各科均分,这个循环最好与上面的循环合并
    for(i=0; i<N; i++)
    {
        totalC += stu[i].c;
        totalLaw += stu[i].law;
    }
    averC = 1.0*totalC/N;
    averLaw = 1.0*totalLaw/N;
    //输出成绩单
    printf("学号\tC\t法律\t学分绩\n");
    for(i=0; i<N; i++)
        printf("%d\t%d\t%d\t%.2f\n",stu[i].num, stu[i].c, stu[i].law, stu[i].aver);
    printf("科均分\t%.2f\t%.2f\n\n",averC, averLaw);
    //输出得奖学金(学分绩高于80且没有挂科)的同学学号
    printf("得奖学金的同学的学号是:\n");
    for(i=0; i<N; i++)
        if(stu[i].c>=60&&stu[i].law>=60&&stu[i].aver>=80)
            printf("%d ",stu[i].num);
    return 0;
}

  例3:教材P276例10.8,利用结构数组表示待救援的地点,计算了救援需要的时间

  •   原点: 大本营,救生船每次从大本营出发,救了人之后将人送回大本营
  •   人们在屋顶暂避,每个屋顶由其位置坐标和其上的人数表示。
  •   救生船速度50米/分钟;
  •   逐个屋顶救人,每人上船1分钟,下船0.5分钟。
  •   给定屋顶数以及每个屋顶的坐标和人数,求出所有人都到达大本营并登陆所用的时间。

  

  请阅读程序,运行参考资料中提供的代码(区别在于将结构定义放在了main函数之前,为减少运行中需要输入数据的麻烦,将输入重定向到文件sos.txt,请将sos.txt复制到源代码同一文件夹中。)

  程序如下,下载sos.txt,点这里

#include <stdio.h>
#include <math.h>
#define NUM 50
#define SPEED 50.0
#define UP 1.0
#define DOWN 0.5

struct Roof
{
    float x, y;  //屋顶的位置
    int p;       //屋顶上的人数
};

int main( )
{
    struct Roof roofs[NUM];
    float totalTime = 0;
    int i;
    float x,y;
    int p;
    freopen("sos.txt", "r", stdin);
    //用循环输入每个屋顶位置及人数
    for(i=0; i<NUM; i++)
    {
        scanf("%f%f%d", &x, &y, &p);
        roofs[i].x = x;
        roofs[i].y = y;
        roofs[i].p = p;
    }

    //计算救援时间
    for(i=0; i<NUM; i++)
    {
        x = roofs[i].x;
        y = roofs[i].y;
        p = roofs[i].p;

        //累加双程航行时间
        totalTime += 2 *sqrt(x*x + y*y)/SPEED;

        //累加上下船时间
        totalTime += p * (UP + DOWN);
    }

    //输出救援时间
    printf("总时间: %.2f\n", totalTime);

    //输出屋顶信息
    for(i=0; i<NUM; i++)
    {

        printf("No. %d ---(%.2f, %.2f), %d\n",i+1, roofs[i].x, roofs[i].y, roofs[i].p);
    }
    return 0;
}

  练习3:请将结构数组改写为如下形式,修改程序使完成相同的功能

struct Point
{
    float x, y;
};
struct Roof
{
    struct Point loc;
    int p;
};

参考解答:

#include <stdio.h>
#include <math.h>
#define NUM 50
#define SPEED 50.0
#define UP 1.0
#define DOWN 0.5
struct Point
{
    float x, y;
};
struct Roof
{
    struct Point loc;  //屋顶的位置
    int p;             //屋顶上的人数
};

int main( )
{
    struct Roof roofs[NUM];
    float totalTime = 0;
    int i;
    float x,y;
    int p;

    freopen("sos.txt", "r", stdin);
    //用循环输入每个屋顶位置及人数
    for(i=0; i<NUM; i++)
    {
        scanf("%f%f%d", &x, &y, &p);
        roofs[i].loc.x = x;
        roofs[i].loc.y = y;
        roofs[i].p = p;
    }

    //计算救援时间
    for(i=0; i<NUM; i++)
    {

        x = roofs[i].loc.x;
        y = roofs[i].loc.y;
        p = roofs[i].p;

        //累加双程航行时间
        totalTime += 2 *sqrt(x*x + y*y)/SPEED;

        //累加上下船时间
        totalTime += p * (UP + DOWN);
    }

    //输出救援时间
    printf("总时间: %.2f\n", totalTime);

    //输出屋顶信息
    for(i=0; i<NUM; i++)
    {

        printf("No. %d ---(%.2f, %.2f), %d\n",i+1, roofs[i].loc.x, roofs[i].loc.y, roofs[i].p);
    }
    return 0;
}
时间: 2025-01-05 03:42:38

计算机科学-第4周 结构 题目及参考解答的相关文章

计算机科学-第6周 文件 题目及参考解答

<计算机科学>课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 题目:文件salary1.txt是某单位100名员工的工号.基本工资和绩效工资.编程序(1)从文件中读取数据,求出总工资,并在屏幕上显示信息:(2)将完整的工资单保存到文件salary2.txt中.(3)将总工资超过5000元的员工的工号保存到文件rich.txt中.(4)在屏幕上显示工资最高的员工的工资信息提示:(1)定义一个结构体数组保存从文件中读入的

计算机科学-第15周 递归函数 题目及参考解答

<计算机科学>课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 1.阅读下面关于递归函数的程序,在草稿纸上画出函数调用"递推-回归"的过程,得出运行结果,并和实际运行结果进行对照(1) #include <stdio.h> int fact(int n); int main(){ long x=0,y=0; x=5; y=fact(x); printf("%ld\n"

计算机科学-第13周 函数 题目及参考解答

<计算机科学>课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 1.阅读程序:阅读下面的程序,写出运行结果,上机时运行程序,记录结果,从而能够理解函数的用法(1) #include <stdio.h> void fun(int x, int y) { x=x*10; y=y+x; printf("%d\t%d\n",x,y); } int main() { int a=2, b=3; f

法133计算机科学课第9、10周实践题目及参考解答

课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 2398:分段函数求值[双分支] Description 编程序,计算下面函数的值并输出: y = x - 1 (当x>=1), y = -x + 1 (当x<1) Input 一个整型数x Output 按公式计算出的y Sample Input 2 Sample Output 1 参考解答: #include <stdio.h> int main() {

法133计算机科学课第13周实践题目及参考解答

课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 [课后练习1] 完成下面"歌手大奖赛计分程序"的设计(至少一项要求): 1.在歌手大奖赛中,有10位评委为参赛的选手打分,分数为0~10分(运行时由人控制).选手最后得分为去掉一个最高分和一个最低分后的平均值.请编写一个程序实现计分. 2.做一个更通用的计分程序,评委人数n可以在输入成绩之前输入,从而评委人数可以灵活调整. 3.进一步完善程序.一次运行程序只计算

法133计算机科学课第15周实践题目及参考解答

课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 编程练习1:输出1000以内的所有素数. 参考解答: #include<stdio.h> #include<math.h> int main() { int m,i,k,prime; for(m=2;m<=200;m++) { prime=1; k=sqrt(m); for(i=2; i<=k; i++) //最多循环至-- if(m%i==0)

法133计算机科学课第12周实践题目及参考解答

课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 Problem A:2447: 求N组数的最大公约数Description计算一组数的最大公约数Input第一行是数据的组数N,从第二行是N组由两个整数(a和b)构成的输入,a和b之间用空格隔开,每组输入单独占一行Output每组的两个整数(a和b)的最大 公约数,每个结果独占一行Sample Input398 7280 3612 144Sample Output2412

计算机科学-第2周 数组初练-参考解答

<计算机科学>课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 练习一:下面的程序,输出了52张扑克牌(如图),请补充完整程序. #include <stdio.h> int main( ) { char c[4]= {'H','S','D','C'}; int v[13]= {1,2,3,4,5,6,7,8,9,10,11,12,13}; int i,j; for(i=0; i<4; i++) {

计算机科学-第9周 数组、结构体、指针综合练习 题目及参考解答

<计算机科学>课程主页在:http://blog.csdn.net/sxhelijian/article/details/13705597 发现第9周的题目及参考没有公布,补上. 1.阅读程序阅读下面的程序,写出运行结果,上机时运行程序,记录结果,从而能够理解指针的用法(1) #include<stdio.h> int main(){ char a[]="Hello World",*p; int i; i=8; p=a+i; printf("%s\n&