| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1636 人关注过本帖
标题:怎么能让我的input(),seek(),calculate(),output(),sort()函 ...
只看楼主 加入收藏
提升完善自我
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2018-4-11
结帖率:0
收藏
已结贴  问题点数:20 回复次数:1 
怎么能让我的input(),seek(),calculate(),output(),sort()函数全用指针来实现,而且是用指针访问一维数组
#include <stdio.h>
#include <conio.h>
#include <string.h>
struct student {
  long num;
  char name[20];
  char sex[2];
  int age;
  struct Grade {
    int Math;
    int Computer;
    int Physics;
    int English;
  } gra;
  int total;
  float average;
};
void calculate(struct student stu[], int n);
void input(struct student stu[], int n);
void output(struct student stu[], int n);
void seek(struct student stu[], int n);
void sort(struct student stu[], int n);
int main() {
  struct student stu[5];
  input(stu, 5);
  calculate(stu, 5);
  output(stu, 5);
  sort(stu, 5);
  printf("排序后:\n");
  output(stu, 5);
  seek(stu, 5);
} void seek(struct student stu[], int n) {
  char name[20];
  int i;
  printf("\n请输入查找的同学的姓名:\n");
  scanf("%s", name);
  for (i = 0; i < n; i++) {
    if (strcmp(name, stu[i].name) == 0) {
      printf("学号:%d\n", stu[i].num);
      printf("姓名:%s\n", stu[i].name);
      printf("性别:%s\n", stu[i].sex);
      printf("年龄:%d\n", stu[i].age);
      printf("高数成绩:%d\n", stu[i].gra.Math);
      printf("计算机成绩:%d\n", stu[i].);
      printf("物理成绩:%d\n", stu[i].gra.Physics);
      printf("英语成绩:%d\n", stu[i].gra.English);
      printf("总成绩:%d\n", stu[i].total);
      printf("平均成绩:%f\n", stu[i].average);
      break;
    }
  }
  if (i == n) {
    printf("No find\n");
  }
}
void sort(struct student stu[], int n) {
  struct student s = { 0 };
  int i, j;
  for (i = 0; i < n - 1; i++) {
    for (j = 0; j < n - 1; j++) {
      if (stu[j].total < stu[j + 1].total) {
        memcpy(&s, &stu[j], sizeof(struct student));
        memcpy(&stu[j], &stu[j + 1], sizeof(struct student));
        memcpy(&stu[j + 1], &s, sizeof(struct student));
      }
}}} void input(struct student stu[], int n) {
  int i;
  for (i = 0; i < n; i++) {
    printf("\n请输入第%d个同学的学号:\n", i + 1);
    scanf("%d", &stu[i].num);
    printf("\n请输入第%d个同学的姓名:\n", i + 1);
    scanf("%s", stu[i].name);
    printf("\n请输入第%d个同学的性别:\n", i + 1);
    scanf("%s", stu[i].sex);
    printf("\n请输入第%d个同学的年龄:\n", i + 1);
    scanf("%d", &stu[i].age);
    printf("\n请输入第%d个同学的高数成绩:\n", i + 1);
    scanf("%d", &stu[i].gra.Math);
    printf("\n请输入第%d个同学的计算机成绩:\n", i + 1);
    scanf("%d", &stu[i].);
    printf("\n请输入第%d个同学的物理成绩:\n", i + 1);
    scanf("%d", &stu[i].gra.Physics);
    printf("\n请输入第%d个同学的英语成绩:\n", i + 1);
    scanf("%d", &stu[i].gra.English);
  }
}
void calculate(struct student stu[], int n) {
  int i;
  for (i = 0; i < n; i++) {
    stu[i].total =
      stu[i].gra.Math + stu[i]. + stu[i].gra.Physics +
      stu[i].gra.English;
    stu[i].average = (float)stu[i].total / 4;
    printf("输出第%d个同学的总成绩:%d\n", i + 1, stu[i].total);
    printf("输出第%d个同学的平均成绩:%f\n", i + 1, stu[i].average);
}} void output(struct student stu[], int n) {
  int i;
  for (i = 0; i < n; i++) {
    printf("学号:%d\n", stu[i].num);
    printf("姓名:%s\n", stu[i].name);
    printf("性别:%s\n", stu[i].sex);
    printf("年龄:%d\n", stu[i].age);
    printf("高数成绩:%d\n", stu[i].gra.Math);
    printf("计算机成绩:%d\n", stu[i].);
    printf("物理成绩:%d\n", stu[i].gra.Physics);
    printf("英语成绩:%d\n", stu[i].gra.English);
    printf("总成绩:%d\n", stu[i].total);
    printf("平均成绩:%f\n", stu[i].average);
  }
}

搜索更多相关主题的帖子: struct stu student int printf 
2018-04-11 12:34
lanke711
Rank: 9Rank: 9Rank: 9
来 自:流浪在天国之路
等 级:蜘蛛侠
威 望:7
帖 子:317
专家分:1437
注 册:2015-7-16
收藏
得分:20 
用指针?
可以写个链表来实现。

普通人之所以普通,是因为他们普遍有一个通病,那就是认为自己永远普通。
千夫所指,我亦坚持。就算被所有人误解,我也照样守护这一切。
我们总是觉得,这些灵魂的表情,傲慢自大,目中无人,其实,真正目中无人的是我们。它们傲慢的不过是表情,而我们傲慢的却是行为!
记得,是为了忘记!
只要想着有那么一天,我就能忍受现在的每一天!
灾难并不可怕,可怕的是心中没有了希望。
你以为我在天堂,其实我正在路上。
当你觉得自己走不到终点的时候,请不要放弃。或许你的对手也是这种感觉。
2018-04-11 13:18
快速回复:怎么能让我的input(),seek(),calculate(),output(),sort( ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017941 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved