编译没问题,运行就出问题了,找了好久不知道哪里错了,请指教
#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;
}
}
}
}
私以为,你好歹把编译器报的错发一下啊(摔)! 内存溢出 没有开辟空间{:10_266:} 四十二 发表于 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) 四十二 发表于 2016-11-17 23:05
私以为,你好歹把编译器报的错发一下啊(摔)!
忘记这茬了,不好意思 malloc申请的空间不是连续的,在pai()函数中无法用x+i去指向下一个数据吧。 mhp0114 发表于 2017-2-7 13:12
malloc申请的空间不是连续的,在pai()函数中无法用x+i去指向下一个数据吧。
数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。 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;
}
}
}
}
lzgw 发表于 2017-2-7 16:26
数组指针申请的空间,所以是可以的哦。
这个题目我早已解决。
嗯好的,指针数组。 建议用vs,单步去执行,可看出哪里错误
页:
[1]