大一新生关于数组结构的问题

输入一个班N个学生的信息,包括学号、姓名以及C语言的成绩。然后通过输入某一学生的姓名进行查找,如果找到,输出其相关的信息;如果未找到,输出“本班无此人”

#include <stdio.h>
#include <string.h>
typedef struct _stu
{
    char id[20];
    char name[20];
    float c;
}stu;

void finds(stu *s,int n,char *name)
{
      for(int i=0;i<n;i++)
      {
           if(strcmp(s[i].name,name) == 0)
           {
                  printf("学号:%s\t姓名:%s\tC成绩:%.1f",s[i].id,s[i].name,s[i].c);
                  return;
           }       
      }
      printf("本班无此人");
}

int main()
{
      stu s[100];
      int N;
      printf("请输入班级人数:");
      scanf("%d",&N);
      for(int i=0;i<N;i++)
      {
          printf("请输入第%d个学生学号、姓名和C成绩:",i+1);
          scanf("%s %s %f",s[i].id,s[i].name,&s[i].c);
      }
      char find[20];
      printf("请输入搜索学生姓名:");
      finds(s,N,find);
      return 0;
}
参考一下:

#include "stdio.h"

#define N 2
struct student{
    int id;
    char name[20];
    int kaoqun;
    int biaoxian;
    int zuoye;
    int biji;
    int sum;
}stud[N],t;

int main()
{
    int i,j;
    for(i=0;i<N;i++){
        printf("请输入第%d个学生信息\n",i+1);
        scanf("%d %s",&stud[i].id,&stud[i].name);
        fflush(stdin);
        scanf("%d %d %d %d",&stud[i].kaoqun,&stud[i].biaoxian,&stud[i].zuoye,&stud[i].biji);
        stud[i].sum = stud[i].kaoqun*0.3+stud[i].biaoxian*0.3+stud[i].zuoye*0.3+stud[i].biji*0.1;
    }
    
    //排序
    
    for (i = 0; i < N - 1; i++){
        for (j = 0; j < N - 1 - i; j++){ //按成绩对学生信息进行排序
            if (stud[j].sum > stud[j + 1].sum){ //整型数字的比较
                t = stud[j];
                stud[j] = stud[j + 1];
                stud[j + 1] = t;
            }
        }
    }
    //打印
    printf("学号\t姓名\t考勤\t表现\t作业\t笔记\t总分\t\n");
    for (i = 0; i < N; i++){
        printf("%d\t", stud[i].id);
        printf("%s\t", stud[i].name);
        printf("%d\t", stud[i].kaoqun);
        printf("%d\t", stud[i].biaoxian);
        printf("%d\t", stud[i].zuoye);
        printf("%d\t", stud[i].biji);
        printf("%d \n", stud[i].sum);
    }
    
    return 1;
}