Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7534746
  • 博文数量: 961
  • 博客积分: 15795
  • 博客等级: 上将
  • 技术积分: 16612
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-07 14:23
文章分类

全部博文(961)

文章存档

2016年(1)

2015年(61)

2014年(41)

2013年(51)

2012年(235)

2011年(391)

2010年(181)

分类: 嵌入式

2011-02-28 09:00:28

  1. #include <stdio.h>
  2. #define N 5                /* 学生总数,为了方便程序输出结果的显示,这里设为5 */

  3. struct student                /* 定义一个结构体数组,存储全班学生的学号和成绩 */
  4. {
  5.   int id;                    /* 学号 */
  6.   int score;                 /* 成绩 */
  7. } stu[N];

  8. int main()
  9. {
  10.   struct student *pt, *p[N];     /* 定义指向结构体的指针pt和指向结构体的指针构成的指针数组p */
  11.   int i, j, k, sum=0;            /* sum为全班的总成绩 */
  12.   printf ("Please input ID and Score :\n");
  13.   for(i=0; i<=N-1; i++)
  14.   {
  15.     scanf("%d%d", &stu[i].id, &stu[i].score);        /* 输入学生的学号和成绩 */
  16.     p[i] = &stu[i];            /* 将指针数组p的第i个元素(指针)指向结构体数组的第i个元素 */
  17.     sum += stu[i].score;        /* 累计学生的分数 */
  18.   }
  19.   for(i=0; i<=N-2; i++ )         /* 按成绩排序 */
  20.   {
  21.     k = i;                    /* 在第i次循环中,将指向当前最高分数的指针在指针数组p中的下标 */
  22.     for(j=i; j<=N-1; j++)
  23.     {
  24.       if(p[k]->score < p[j]->score)                /* 查找当前最高分数 */
  25.       {
  26.         k = j;                /* k中存放当前最高分数对应的指针在指针数组p中的下标 */
  27.       }
  28.     }
  29.     if(k!=i)                /* 当k不等于i时,交换两个指向结构体的指针 */
  30.     {
  31.       pt = p[i];
  32.       p[i] = p[k];
  33.       p[k] = pt;
  34.     }
  35.   }
  36.   printf("ID Score\n");
  37.   printf("------------------\n");
  38.   for (i=0; i<=N-1; i++)        /* 按排序顺序输出学号和成绩 */
  39.   {
  40.     printf("%d %d\n", (*p[i]).id, p[i]->score);
  41.   }
  42.   printf ("Average score = %d\n", sum/N);        /* 输出平均分数 */
  43.   return 0;
  44. }
阅读(1925) | 评论(0) | 转发(2) |
0

上一篇:线性表

下一篇:共用体

给主人留下些什么吧!~~