一道C语言程序题目,求解答~~
这是程序的主体:structstu{charname[20];floatscore;};intmain(){inti,L;floats;scanf("%d",&L);st...
这是程序的主体:
struct stu
{
char name[20];
float score;
};
int main()
{
int i,L;
float s;
scanf("%d",&L);
struct stu *p;
p=(struct stu*)malloc(sizeof(struct stu)*L);
for (i=0;i<L;i++)
{
p++;
printf("input %dth score",i+1);
scanf("%f",&p[i].score);
}
……………………………………
}
我是想输出用户输入的第一个成绩。但是我输出的s永远是乱码………………求助!!省略号部分要填什么?或者程序怎么改才能把指针调回p[0]………… 展开
struct stu
{
char name[20];
float score;
};
int main()
{
int i,L;
float s;
scanf("%d",&L);
struct stu *p;
p=(struct stu*)malloc(sizeof(struct stu)*L);
for (i=0;i<L;i++)
{
p++;
printf("input %dth score",i+1);
scanf("%f",&p[i].score);
}
……………………………………
}
我是想输出用户输入的第一个成绩。但是我输出的s永远是乱码………………求助!!省略号部分要填什么?或者程序怎么改才能把指针调回p[0]………… 展开
3个回答
展开全部
上面的代码中,没有对s进行输入,所以如果输出s的话,指定会是乱码的啊
把指针调回p[0]的话,可以p--回去
或者在p改变之前,用tmp_p保存起始位置。
struct stu *tmp_p = p;
……
p = tmp_p;
此外,我猜,这个程序中的s是为了保存平均值?
struct stu
{
char name[20];
float score;
};
int main()
{
int i,L;
float s;
scanf("%d",&L);
struct stu *p;
p=(struct stu*)malloc(sizeof(struct stu)*L);
s = 0;
for (i=0;i<L;i++)
{
p++;
printf("input %dth score",i+1);
scanf("%f",&p[i].score);
s+=p[i].score;
}
s/=L; //就是平均值了
delete p;//最后一定要释放内存
}
追问
其实,s是作为一个中间值,接下来是要比较输入成绩的大小,并输出最大值~
追答
哦 这样啊,最好起见名知意的名字max_score之类的,那么实现这个的话,只要稍微修改下就可以了:
struct stu
{
char name[20];
float score;
};
int main()
{
int i,L;
float s;
scanf("%d",&L);
struct stu *p;
p=(struct stu*)malloc(sizeof(struct stu)*L);
struct stu *tmp_p = p;
s = -1; //score 都是正数
for (i=0;i<L;i++)
{
p++;
printf("input %dth score",i+1);
scanf("%f",&p[i].score);
if(p[i].score > s)
s = p[i].score;
}
delete p;//最后一定要释放内存
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
输出第一个成绩的话这样就可以了
#include "stdio.h"
#include <string.h>
#include <stdlib.h>
struct stu
{
char name[20];
float score;
};
int main()
{
int i,L;
float s;
scanf("%d",&L);
struct stu *p;
p=(struct stu*)malloc(sizeof(struct stu)*L);
for (i=0;i<L;i++)
{
p++;
printf("input %dth score",i+1);
scanf("%f",&p[i].score);
}
printf("%f",p[0].score);
}
追问
这样不行啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
#include<stdlib.h>
struct stu
{
char name[20];
float score;
};
int main()
{
int i,L;
float s;
struct stu *p;
scanf("%d",&L);
p=(struct stu*)malloc(sizeof(struct stu)*L);
for (i=0;i<L;i++)
{
//这里不要移动p,不然后面p就指向不正确的位置了
printf("input %dth score: ",i+1);
scanf("%f",&p[i].score);
}
printf("%f\n", p->score );
return 0;
}
追问
但是我需要用p作为指针创建链表,由于是动态空间分配,所以指针好像不能丢把?
追答
指针首位置一定不能丢!
话说,你这程序只是建立了一个数组,看不到链表的痕迹啊!
链表是用next指针串起来的一个一个的node
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询