zoukankan      html  css  js  c++  java
  • 结构体指针排序

    输入不超过30名学生的信息,包括姓名,单科分数,出生年月,对其排序后输出。

      运用知识点:结构体、指针、排序、函数。

      1 #include<stdio.h>
      2 #include<string.h>
      3 
      4 struct birth
      5 {
      6     int y;
      7     int m;
      8     int d;
      9 };
     10 struct student
     11 {
     12     int num;
     13     char name[20];
     14     double score;
     15     struct birth birthday;
     16 };
     17 
     18 
     19 int main()
     20 
     21 {
     22     struct student STU[30],*p;
     23     p=STU;
     24     void name_sort(struct student *p,int n);
     25     void age_sort(struct student *p,int n);
     26     void score_sort(struct student *p,int n);
     27     int i;
     28     printf("请分别输入学生的学号、姓名、一门成绩和出生年月日(输入分数小于0或大于100结束):
    ");
     29     for(i=0;i<30;i++)
     30     {
     31         scanf("%d%s%lf%d%d%d",&(p+i)->num,(p+i)->name,&(p+i)->score,&(p+i)->birthday.y,&(p+i)->birthday.m,&(p+i)->birthday.d);
     32         if((p+i)->score>100 || (p+i)->score<0) break;
     33     }
     34     int n=i;
     35     
     36     printf("
    按照姓名排序:
    ");
     37     name_sort(p,n);
     38     printf("学号		名字		分数	年	月	日
    ");
     39     for(i=0;i<n;i++)
     40     {
     41         printf("%d		%s		%.2lf	%d	%d	%d	
    ",(p+i)->num,(p+i)->name,(p+i)->score,(p+i)->birthday.y,(p+i)->birthday.m,(p+i)->birthday.d);
     42     }
     43     
     44     printf("
    按照分数从大到小排序:
    ");
     45     printf("学号		名字		分数	年	月	日
    ");
     46     score_sort(p,n);
     47     for(i=n;i>=0;i--)
     48     {
     49         printf("%d		%s		%.2lf	%d	%d	%d	
    ",(p+i)->num,(p+i)->name,(p+i)->score,(p+i)->birthday.y,(p+i)->birthday.m,(p+i)->birthday.d);
     50     }
     51     
     52     printf("
    按照年龄从大到小排序:
    ");
     53     printf("学号		名字		分数	年	月	日
    ");
     54     age_sort(p,n);
     55     for(i=0;i<n;i++)
     56     {
     57         printf("%d		%s		%.2lf	%d	%d	%d	
    ",(p+i)->num,(p+i)->name,(p+i)->score,(p+i)->birthday.y,(p+i)->birthday.m,(p+i)->birthday.d);
     58     }
     59     
     60     
     61     return 0;
     62 }
     63 void name_sort(struct student *p,int n)//姓名排序
     64 {
     65     int i, j;
     66     struct student temp;
     67     for (i = 0; i < n - 1; i++)
     68         for (j = 0; j < n - 1 - i; j++)
     69             if (strcmp((p + j)->name, (p + j + 1)->name) > 0){
     70                 temp = *(p + j);
     71                 *(p + j) = *(p + j + 1);
     72                 *(p + j + 1) = temp;}
     73     return;
     74     return;
     75 }
     76 void age_sort(struct student *p,int n)//年龄排序
     77 {
     78     int i, j, b1, b2;
     79     struct student temp;
     80     for (i = 0; i<n - 1; i++)
     81         for (j = 0; j < n - 1 - i; j++)
     82         {
     83             b1 = (p + j)->birthday.y * 10000 + (p + j)->birthday.m * 100 + (p + j)->birthday.d;
     84             b2 = (p + j + 1)->birthday.y * 10000 + (p + j + 1)->birthday.m * 100 + (p + j + 1)->birthday.d;
     85             if (b1 > b2)temp = *(p + j), *(p + j) = *(p + j + 1), *(p + j + 1) = temp;
     86         }
     87     return;
     88 }
     89 void score_sort(struct student *p, int n){  //分数排序
     90     int i, j;
     91     struct student temp;
     92     for(i=0;i<n-1;i++)
     93         for(j=0;j<n-1-i;j++){
     94             if((p+j)->score>(p+j+1)->score){
     95                 temp = *(p + j);
     96                 *(p + j) = *(p + j + 1);
     97                 *(p + j + 1) = temp;
     98             }
     99         }
    100 }
  • 相关阅读:
    nodejs async waterfull 小白向
    nodejs async series 小白向
    MySQL 分区介绍总结
    cocos2d-x 一些实用的函数
    LeetCode(61)-Valid Palindrome
    ganglia错误解决
    (6)uboot具体解释——关闭缓存和mmu
    Linux下设置MySQL不区分大写和小写
    火狐与IE的7个JavaScript差异
    商业研究(8):汽车交通
  • 原文地址:https://www.cnblogs.com/liangjiahao713/p/6111645.html
Copyright © 2011-2022 走看看