鱼C论坛

 找回密码
 立即注册
查看: 3137|回复: 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;
                        }
                }
        }
}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-11-17 23:05:48 | 显示全部楼层
私以为,你好歹把编译器报的错发一下啊(摔)!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-11-18 00:04:20 | 显示全部楼层
内存溢出    没有开辟空间  
小甲鱼最新课程 -> https://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)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

忘记这茬了,不好意思
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

  4. #define N 5

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

  9. void main()
  10. {
  11.         int i;
  12.         double a[N] , *p_a;
  13.         char *p_b[N];
  14.         p_a = a;
  15.        
  16.         for(i = 0; i < N; ++i)
  17.         {
  18.                 p_b[i] = (char*)malloc(10*sizeof(char));       
  19.                 printf("请输入评委编号\n");
  20.                
  21.                 scanf("%s",p_b[i]);
  22.                 printf("请输入得分\n");
  23.                 scanf("%lf",&a[i]);
  24.         }
  25.         for(i = 0; i < N; ++i)
  26.         {
  27.                 printf("评委%s打分%.2lf\n", p_b[i], a[i]);
  28.         }

  29.         pai(a, p_b);
  30.         printf(" 排序后得分为:\n");
  31.         for(i = 0; i < N; ++i)
  32.         {
  33.                 printf("%10s", p_b[i]);
  34.         }
  35.         printf("\n");
  36.         for(i = 0; i < N; ++i)
  37.         {
  38.                 printf("%10.2lf", a[i]);
  39.         }
  40.         printf("\n");
  41.         printf("最高分%.2lf\n", max(p_a));
  42.         printf("最低分%.2lf\n", min(p_a));
  43.         printf("去掉一个最高分%.2lf, 去掉一个最低分%.2lf, 平均得分%.2lf\n", max(p_a), min(p_a), ping(p_a));
  44. }

  45. double max(double * x)                                //利用指针将数组进行对比,取最大值
  46. {
  47.         double n;
  48.         int i;
  49.         n = *x;                                                        //将分数第一个地址赋给指针X
  50.         for(i = 1; i < N; ++i)
  51.         {
  52.                 if(n < *(x + i))                        //取+1地址位的值与前位地址位的值对比,如果大于前位地址的值,就将值赋给前位地址
  53.                 {
  54.                         n = *(x + i);
  55.                 }
  56.         }
  57.         return (n);                                                //返回最大的值给主调函数
  58. }

  59. double min(double * x)                                //将分数第一位地址赋给指针x
  60. {
  61.         double n;
  62.         int i;
  63.         n = *x;
  64.         for(i = 1; i < N; ++i)
  65.         {
  66.                 if(n > *(x + i))
  67.                 {
  68.                         n = *(x + i);
  69.                 }
  70.         }
  71.         return (n);
  72. }

  73. double ping(double * x)
  74. {
  75.         double n = 0;
  76.         int i;
  77.         for(i = 0; i < N; ++i)
  78.         {
  79.                 n += *(x + i);
  80.         }
  81.         n = (n-max(x)-min(x))/(double)(N - 2);
  82.                 return (n);
  83. }

  84. void pai(double * x, char **y)                                         //使用直接对比进行排序
  85. {
  86.        
  87.         double temp;
  88.         char  *t;
  89.         int i, j;
  90.         for(i = 0; i < N-1; ++i)
  91.         {
  92.                 for(j = i+1; j < N  ; ++j)
  93.                 {
  94.                         if(x[i]< x[j])
  95.                         {
  96.                                 temp = x[i];
  97.                                 x[i] = x[j];
  98.                                 x[j] = temp;

  99.                                 t = y[i];
  100.                                 y[i] = y[j];
  101.                                 y[j] = t;
  102.                         }
  103.                 }
  104.         }       
  105. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

嗯好的,指针数组。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-2-8 12:33:23 | 显示全部楼层
建议用vs,单步去执行,可看出哪里错误
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-9 18:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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