鱼C论坛

 找回密码
 立即注册
查看: 2787|回复: 9

编译没问题,运行就出问题了,找了好久不知道哪里错了,请指教

[复制链接]
发表于 2016-11-17 22:11:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>
#include <string.h>
#include <malloc.h>

#define N 3

double max();           //求最高分及其评委
double min();           //求最低分及其评委
double ping();          //求平均分
void pai();             //得分排序

void main()
{
        int i;
        double a[N] , *p_a;
        char *p_b[N];
        p_a = a;
       
        for(i = 0; i < N; ++i)
        {
                p_b[i] = (char*)malloc(10*sizeof(char));       
                printf("请输入评委编号\n");
               
                scanf("%s",p_b[i]);
                printf("请输入得分\n");
                scanf("%lf",&a[i]);
        }
        for(i = 0; i < N; ++i)
        {
                printf("评委%s打分%.2lf\n", p_b[i], a[i]);
        }

        pai(a, p_b);
        printf(" 排序后得分为:");
        for(i = 0; i < N; ++i)
        {
                printf("%-6s", p_b[i]);
        }
        printf("\n");
        for(i = 0; i < N; ++i)
        {
                printf("%-6lf", a[i]);
        }
        printf("\n");

        printf("最高分%.2lf\n", max(p_a));
        printf("最低分%.2lf\n", min(p_a));
        printf("去掉一个最高分%.2lf, 去掉一个最低分%.2lf, 平均得分%.2lf\n", max(p_a), min(p_a), ping(p_a));
}

double max(double * x)                                //利用指针将数组进行对比,取最大值
{
        double n;
        int i;
        n = *x;                                                        //将分数第一个地址赋给指针X
        for(i = 1; i < N; ++i)
        {
                if(n < *(x + i))                        //取+1地址位的值与前位地址位的值对比,如果大于前位地址的值,就将值赋给前位地址
                {
                        n = *(x + i);
                }
        }
        return (n);                                                //返回最大的值给主调函数
}

double min(double * x)                                //将分数第一位地址赋给指针x
{
        double n;
        int i;
        n = *x;
        for(i = 1; i < N; ++i)
        {
                if(n > *(x + i))
                {
                        n = *(x + i);
                }
        }
        return (n);
}

double ping(double * x)
{
        double n = 0;
        int i;
        for(i = 0; i < N; ++i)
        {
                n += *(x + i);
        }
        n = (n-max(x)-min(x))/(double)(N - 2);
                return (n);
}


void pai(double * x, char *y)                                         //使用直接对比进行排序
{
       
        double temp;
        char  *t;
        int i, j;
        for(i = 0; i < N-1; ++i)
        {
                for(j = i+1; j < N  ; ++j)
                {
                        if((x+i)< (x+j))
                        {
                                temp = x[i];
                                x[i] = x[j];
                                x[j] = temp;

                                t = y[i];
                                y[i] = y[j];
                                y[j] = t;
                        }
                }
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-11-17 23:05:48 | 显示全部楼层
私以为,你好歹把编译器报的错发一下啊(摔)!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-11-18 00:04:20 | 显示全部楼层
内存溢出    没有开辟空间  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-11-18 08:43:28 | 显示全部楼层
四十二 发表于 2016-11-17 23:05
私以为,你好歹把编译器报的错发一下啊(摔)!

--------------------Configuration: 打分 - Win32 Debug--------------------
Compiling...
打分.c
D:\C语言学习\打分\打分.c(110) : warning C4047: '=' : 'char *' differs in levels of indirection from 'char '
D:\C语言学习\打分\打分.c(112) : warning C4047: '=' : 'char ' differs in levels of indirection from 'char *'

打分.obj - 0 error(s), 0 warning(s)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-11-18 08:44:12 | 显示全部楼层
四十二 发表于 2016-11-17 23:05
私以为,你好歹把编译器报的错发一下啊(摔)!

忘记这茬了,不好意思
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-2-7 13:12:59 | 显示全部楼层
malloc申请的空间不是连续的,在pai()函数中无法用x+i去指向下一个数据吧。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-2-7 16:26:11 | 显示全部楼层
mhp0114 发表于 2017-2-7 13:12
malloc申请的空间不是连续的,在pai()函数中无法用x+i去指向下一个数据吧。

数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-2-7 16:32:36 | 显示全部楼层
mhp0114 发表于 2017-2-7 13:12
malloc申请的空间不是连续的,在pai()函数中无法用x+i去指向下一个数据吧。
#include <stdio.h>
//#include <string.h>
#include <malloc.h>

#define N 5

double max();           //求最高分及其评委
double min();           //求最低分及其评委
double ping();          //求平均分
void pai();             //得分排序

void main()
{
        int i;
        double a[N] , *p_a;
        char *p_b[N];
        p_a = a;
        
        for(i = 0; i < N; ++i)
        {
                p_b[i] = (char*)malloc(10*sizeof(char));        
                printf("请输入评委编号\n");
                
                scanf("%s",p_b[i]);
                printf("请输入得分\n");
                scanf("%lf",&a[i]);
        }
        for(i = 0; i < N; ++i)
        {
                printf("评委%s打分%.2lf\n", p_b[i], a[i]);
        }

        pai(a, p_b);
        printf(" 排序后得分为:\n");
        for(i = 0; i < N; ++i)
        {
                printf("%10s", p_b[i]);
        }
        printf("\n");
        for(i = 0; i < N; ++i)
        {
                printf("%10.2lf", a[i]);
        }
        printf("\n");
        printf("最高分%.2lf\n", max(p_a));
        printf("最低分%.2lf\n", min(p_a));
        printf("去掉一个最高分%.2lf, 去掉一个最低分%.2lf, 平均得分%.2lf\n", max(p_a), min(p_a), ping(p_a));
}

double max(double * x)                                //利用指针将数组进行对比,取最大值
{
        double n;
        int i; 
        n = *x;                                                        //将分数第一个地址赋给指针X
        for(i = 1; i < N; ++i)
        {
                if(n < *(x + i))                        //取+1地址位的值与前位地址位的值对比,如果大于前位地址的值,就将值赋给前位地址
                {
                        n = *(x + i);
                }
        }
        return (n);                                                //返回最大的值给主调函数
}

double min(double * x)                                //将分数第一位地址赋给指针x
{
        double n;
        int i;
        n = *x;
        for(i = 1; i < N; ++i)
        {
                if(n > *(x + i))
                {
                        n = *(x + i);
                }
        }
        return (n);
}

double ping(double * x)
{
        double n = 0;
        int i;
        for(i = 0; i < N; ++i)
        {
                n += *(x + i);
        }
        n = (n-max(x)-min(x))/(double)(N - 2);
                return (n);
}

void pai(double * x, char **y)                                         //使用直接对比进行排序
{
        
        double temp;
        char  *t;
        int i, j;
        for(i = 0; i < N-1; ++i)
        {
                for(j = i+1; j < N  ; ++j)
                {
                        if(x[i]< x[j])
                        {
                                temp = x[i];
                                x[i] = x[j];
                                x[j] = temp;

                                t = y[i];
                                y[i] = y[j];
                                y[j] = t;
                        }
                }
        }        
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-2-7 20:43:40 | 显示全部楼层
lzgw 发表于 2017-2-7 16:26
数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。

嗯好的,指针数组。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-2-8 12:33:23 | 显示全部楼层
建议用vs,单步去执行,可看出哪里错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-27 22:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表