| 网站首页 | 业界新闻 | 群组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
共有 395 人关注过本帖, 1 人收藏
标题:大佬们好, 帮忙分析一下到底是错在哪里了 感谢
只看楼主 加入收藏
风流泰
Rank: 1
等 级:新手上路
帖 子:62
专家分:0
注 册:2018-9-29
结帖率:92%
  已结贴   问题点数:19  回复次数:4   
大佬们好, 帮忙分析一下到底是错在哪里了 感谢
#include<stdio.h>
#include<stdlib.h>
struct Student{
    char name[20];
    int age;
    float score;
};
void InputStudent(int len,struct Student*p);// 输入函数声明
void BubbleSort(int len,struct Student*p); //排序函数声明
void OutputStudent(int len,struct Student*p);//输出函数声明
int main(int argc,const char*argv[]){
    int len; //length 是长度的缩写,用于提示用户输入学生的个数
    struct Student*p=NULL; //用于存放动态内存的首地址
    printf("请输入学生的个数:len=");//动态数组的长度可以由用户指定
    scanf("%d",&len);
    p=malloc(len*sizeof*p);//动态构造一维数组
    InputStudent(len,p);
    BubbleSort(len,p);
    OutputStudent(len,p);
    return 0;
}
void InputStudent(int len,struct Student*p){ //输入学生信息
    int i;
    for(i=0;i<len;i++){
        printf("请输入第%dge学生的信息:\n",i+1);
        printf("name=");
        scanf("%s",(p+i)->name); //name是数组名,本身就是数组第一个元素的地址,所以前面不需要加&
        printf("age=");
        scanf("%d",(p+i)->age);//age是int型的,所以前面不需要加&
        printf("score=");
        scanf("%f",&(p+i)->score);
    } printf("\n");
    return;  
}
void BubbleSort(int len,struct Student*p){ //BubbleSort是冒泡排序的英文单词
    struct Student buf;
    int i;
    int j;
    for(i=0;i<len-1;i++){
        for(j=0;j<len-1-i;j++){
            if((p+j)->score<(p+j+1)->score){
                buf=*(p+j)
                *(p+j)=*(p+j+1);
                *(p+j+1)=buf;
            }
        }
    }
    return;
}
void OutputStudent(int len;struct Student*p){ //输出学生信息
    int i;
    printf("按成绩高低输出学生的信息:\n\n");
    for(i=0;i<len;i++){
        printf("第%d个学生的信息是:\n",i+1);
        printf("name=%s\n",(p+i)->name);
        printf("age=%d\n",(p+i)->age);
        printf("score=%f\n",(p+i)->score);
    }  
    return;
}
/  错误提示:   *16    23    C:\Users\WP-S10\Desktop\未命名1.cpp    [Error] invalid conversion from 'void*' to 'Student*' [-fpermissive]
43    5    C:\Users\WP-S10\Desktop\未命名1.cpp    [Error] no match for 'operator*' (operand types are 'Student' and 'Student*')
50    27    C:\Users\WP-S10\Desktop\未命名1.cpp    [Error] expected ')' before ';' token
50    44    C:\Users\WP-S10\Desktop\未命名1.cpp    [Error] expected initializer before ')' token*/
2019-01-18 21:26
ZJYTY
Rank: 6Rank: 6
等 级:侠之大者
威 望:2
帖 子:77
专家分:482
注 册:2018-12-20
  得分:10 
程序代码:
#include<stdio.h>
#include<stdlib.h>
struct Student{
    char name[32];
    int age;
    float score;
};
void InputStudent(int len,struct Student*p);// 输入函数声明
void BubbleSort(int len,struct Student*p); //排序函数声明
void OutputStudent(int len,struct Student*p);//输出函数声明
int main(int argc,const char*argv[]){
    int len; //length 是长度的缩写,用于提示用户输入学生的个数
    struct Student*p=NULL; //用于存放动态内存的首地址
    printf("请输入学生的个数:len=");//动态数组的长度可以由用户指定
    scanf("%d",&len);
    p=malloc(len*sizeof*p);//动态构造一维数组
    InputStudent(len,p);
    BubbleSort(len,p);
    OutputStudent(len,p);
    return 0;
}
void InputStudent(int len,struct Student*p){ //输入学生信息
    int i;
    for(i=0;i<len;i++){
        printf("请输入第%dge学生的信息:\n",i+1);
        printf("name=");
        scanf("%s",(p+i)->name); //name是数组名,本身就是数组第一个元素的地址,所以前面不需要加&
        printf("age=");
        scanf("%d",&(p+i)->age);//age是int型的,所以前面不需要加&                            //前面加&
        printf("score=");
        scanf("%f",&(p+i)->score);
    } printf("\n");
    return;  
}
void BubbleSort(int len,struct Student*p){ //BubbleSort是冒泡排序的英文单词
    struct Student buf;
    int i;
    int j;
    for(i=0;i<len-1;i++){
        for(j=0;j<len-1-i;j++){
            if((p+j)->score<(p+j+1)->score){
                buf=*(p+j);
                    *(p+j)=*(p+j+1);
                *(p+j+1)=buf;
            }
        }
    }
    return;
}
void OutputStudent(int len,struct Student*p){ //输出学生信息                      //注意函数形参格式
    int i;
    printf("按成绩高低输出学生的信息:\n\n");
    for(i=0;i<len;i++){
        printf("第%d个学生的信息是:\n",i+1);
        printf("name=%s\n",(p+i)->name);
        printf("age=%d\n",(p+i)->age);
        printf("score=%f\n",(p+i)->score);
    }  
    return;
}


附件: 您没有浏览附件的权限,请 登录注册

-------------------------------若有不当之处,敬请谅解-------------------------------
2019-01-19 16:44
洛铭
Rank: 2
等 级:论坛游民
帖 子:1
专家分:10
注 册:2019-1-25
  得分:10 
回复 2楼 ZJYTY
没有free
2019-01-25 19:15
ZJYTY
Rank: 6Rank: 6
等 级:侠之大者
威 望:2
帖 子:77
专家分:482
注 册:2018-12-20
  得分:0 
回复 3楼 洛铭
嗯,这个地方没注意到

-------------------------------若有不当之处,敬请谅解-------------------------------
2019-01-26 20:30
风流泰
Rank: 1
等 级:新手上路
帖 子:62
专家分:0
注 册:2018-9-29
  得分:0 
回复 2楼 ZJYTY
非常感谢
2019-02-08 19:05







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

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