lzgw 发表于 2016-11-17 22:11:55

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

#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 , *p_a;
        char *p_b;
        p_a = a;
       
        for(i = 0; i < N; ++i)
        {
                p_b = (char*)malloc(10*sizeof(char));       
                printf("请输入评委编号\n");
               
                scanf("%s",p_b);
                printf("请输入得分\n");
                scanf("%lf",&a);
        }
        for(i = 0; i < N; ++i)
        {
                printf("评委%s打分%.2lf\n", p_b, a);
        }

        pai(a, p_b);
        printf(" 排序后得分为:");
        for(i = 0; i < N; ++i)
        {
                printf("%-6s", p_b);
        }
        printf("\n");
        for(i = 0; i < N; ++i)
        {
                printf("%-6lf", a);
        }
        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;
                                x = x;
                                x = temp;

                                t = y;
                                y = y;
                                y = t;
                        }
                }
        }
}

四十二 发表于 2016-11-17 23:05:48

私以为,你好歹把编译器报的错发一下啊(摔)!

小人 发表于 2016-11-18 00:04:20

内存溢出    没有开辟空间{:10_266:}

lzgw 发表于 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)

lzgw 发表于 2016-11-18 08:44:12

四十二 发表于 2016-11-17 23:05
私以为,你好歹把编译器报的错发一下啊(摔)!

忘记这茬了,不好意思

mhp0114 发表于 2017-2-7 13:12:59

malloc申请的空间不是连续的,在pai()函数中无法用x+i去指向下一个数据吧。

lzgw 发表于 2017-2-7 16:26:11

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

数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。

lzgw 发表于 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 , *p_a;
        char *p_b;
        p_a = a;
       
        for(i = 0; i < N; ++i)
        {
                p_b = (char*)malloc(10*sizeof(char));       
                printf("请输入评委编号\n");
               
                scanf("%s",p_b);
                printf("请输入得分\n");
                scanf("%lf",&a);
        }
        for(i = 0; i < N; ++i)
        {
                printf("评委%s打分%.2lf\n", p_b, a);
        }

        pai(a, p_b);
        printf(" 排序后得分为:\n");
        for(i = 0; i < N; ++i)
        {
                printf("%10s", p_b);
        }
        printf("\n");
        for(i = 0; i < N; ++i)
        {
                printf("%10.2lf", a);
        }
        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< x)
                        {
                                temp = x;
                                x = x;
                                x = temp;

                                t = y;
                                y = y;
                                y = t;
                        }
                }
        }       
}

mhp0114 发表于 2017-2-7 20:43:40

lzgw 发表于 2017-2-7 16:26
数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。

嗯好的,指针数组。

geekerr 发表于 2017-2-8 12:33:23

建议用vs,单步去执行,可看出哪里错误
页: [1]
查看完整版本: 编译没问题,运行就出问题了,找了好久不知道哪里错了,请指教