解答一个C语言程序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解答一个C语言程序相关的知识,希望对你有一定的参考价值。

程序如下:
main()

int num1,num2;
int *numa=&num1,*numb=&num2;
printf("input two numbers:\n");
scanf("%d%d",&num1,&num2);
if(*numa>*numb)
f(numa,numb);
printf("min=%d,max=%d",*numa,*numb);
printf("\n");

void f(int *pa,int *pb)

int pointer;
pointer=*pa;
*pa=*pb;
*pb=pointer;

将程序改成如下时:
main()

int num1,num2;
int *numa=&num1,*numb=&num2;
printf("input two numbers:\n");
scanf("%d%d",&num1,&num2);
if(*numa>*numb)
f(numa,numb);
printf("\n");

f(int *pa,int *pb)

int pointer;
pointer=*pa;
*pa=*pb;
*pb=pointer;
printf("min=%d,max=%d",*numa,*numb);

为什么输不出运算结果呢。
还有这个函数为什么是空类型的。

如过你要在子函数中搞好交换并输出…这是可以的.但…假如你的if不成立呢?不成立就运行那个输出换行 参考技术A 你调试了么?调试一下不就知道哪里出毛病了。 参考技术B 空的就是不用返回值,也就是不用return.
而你不写void的时候,默认为整形
需要一个返回值作用结束,也就量需要一个return.

你这里要求的就是不用返回值,直接打印出来就OK了,所以用void
参考技术C printf("min=%d,max=%d",*numa,*numb);
这里应该是 *pa *pb 吧。。。不然怎么编译通过。。。
还有你函数不声明怎么能编译通过的啊
你第二个函数 当*numa>*numb的时候才执行f函数
但是你的输出写在了f函数内部
所以你输入的 *numa<*numb的时候就没输出了啊
应该在if语句后面加else printf("min=%d,max=%d",*numa,*numb);就可以了
为什么是空类型的。。因为它不需要返回值
你也可以写成有返回值的,只是这个返回值没有意义而已
参考技术D 返回值默认为整形,你的程序不需要返回,以为你的形参(形式参数,就是f函数中的Pa,pb)
指针,修改了相应的内存的值了。

寻求解答 C语言做学生成绩管理系统

只需要
1 成绩输入
2求平均成绩
3平均成绩输出
4平均成绩排序
5退出程序

/******头文件(.h)***********/
#include "stdio.h" /*I/O函数*/
#include "stdlib.h" /*其它说明*/
#include "string.h" /*字符串函数*/
#include "conio.h" /*屏幕操作函数*/
#include "mem.h" /*内存操作函数*/
#include "ctype.h" /*字符操作函数*/
#include "alloc.h" /*动态地址分配函数*/
#define N 3 /*定义常数*/
typedef struct z1 /*定义数据结构*/
char no[11];
char name[15];
int score[N];
float sum;
float average;
int order;
struct z1 *next;
STUDENT;
/*菜单函数,返回值为整数*/
menu_select()

char *menu[]=" ***************MENU***************", /*定义菜单字符串数组*/
" 0. Init list", /*初始化*/
" 1. Enter list", /*输入记录*/
" 2. Print list ", /*显示单链表中所有记录*/
" 3. Sort to make new file", /*排序*/
" 4. Search record by name or NO.", /*按照姓名查找记录*/
" 5. Insert record to list ", /*插入记录到表中*/
" 6. Delete a record from list", /*从表中删除记录*/
" 7. Save the file", /*将单链表中记录保存到文件中*/
" 8. Load the file", /*从文件中读入记录*/
" 9. Statistics", /*统计*/
" 10. Quit", /*退出*/
" ",
" ", /*屏幕调节,没有实际意义*/
" ",
" ***********************************",
" ",
" ",;
char s[3]; /*以字符形式保存选择号*/
int c,i; /*定义整形变量*/
textbackground(GREEN|BLUE); /*设置背景颜色为蓝绿色*/
gotoxy(1,25); /*移动光标*/
printf("Press any key enter menu......\\n"); /*压任一键进入主菜单*/
getch(); /*输入任一键*/
clrscr(); /*清屏*/
for(i=0;i<16;i++) /*输出主菜单数组*/
gotoxy(10,i+1);
cprintf("%s",menu[i]);

window(1,1,80,25); /*恢复原窗口大小*/
gotoxy(10,21); /*移动光标*/
doprintf("\\n Enter you choice(0~10):"); /*在菜单窗口外显示提示信息*/
scanf("%s",s); /*输入选择项*/
c=atoi(s); /*将输入的字符串转化为整形数*/
while(c<0||c>10); /*选择项不在0~10之间重输*/
return c; /*返回选择项,主程序根据该数调用相应的函数*/

/*初始化链表,可以实现对另一组数据的处理*/
STUDENT *init() /*初始化链表*/
return NULL;
/*创建链表,完成数据录入功能*/
STUDENT *create()
int i; int s;
STUDENT *h=NULL,*info; /* STUDENT指向结构体的指针*/
for(;;)
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info) /*如果指针info为空*/

printf("\\nOut of memory"); /*输出内存溢出*/
return NULL; /*返回空指针*/

printf("Input imformation as follow.\\n");
printf("Press \'#\'after\'Enter NO\'to end the input.\\n");
inputs("Enter NO.:",info->no,11); /*输入学号并校验*/
if(info->no[0]==\'#\') break; /*如果学号首字符为#则结束输入*/
inputs("Enter name:",info->name,15); /*输入姓名,并进行校验*/
printf("Please input %d scores \\n",N); /*提示开始输入成绩*/
s=0; /*计算每个学生的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次*/

do
printf("score%d:",i+1); /*提示输入第几门课程*/
scanf("%d",&info->score[i]); /*输入成绩*/
if(info->score[i]>100||info->score[i]<0)/*确保成绩在0~100之间*/
printf("Bad data,repeat input\\n"); /*出错提示信息*/
while(info->score[i]>100||info->score[i]<0);
s=s+info->score[i]; /*累加各门课程成绩*/

info->sum=s; /*将总分保存*/
info->average=(float)s/N; /*求出平均值*/
info->order=0; /*未排序前此值为0*/
info->next=h; /*将头结点做为新输入结点的后继结点*/
h=info; /*新输入结点为新的头结点*//*没排序前,后输入的数据将排在最上*/

return(h); /*返回头指针*/

/*自定义输入控制函数inputs*/
inputs(char *prompt, char *s, int count)

char p[255];
doprintf(prompt); /*显示提示信息*/
scanf("%s",p); /*输入字符串*/
if(strlen(p)>count)printf("\\n Too long! \\n"); /*进行长度校验,超过count值重输入*/
while(strlen(p)>count);
strcpy(s,p); /*将输入的字符串拷贝到字符串s中*/

/*显示模块*/
void print(STUDENT *h)
int i=0; /* 统计记录条数*/
STUDENT *p; /*移动指针*/
clrscr(); /*清屏*/
p=h; /*初值为头指针*/
printf("\\n\\n\\n****************************STUDENT**********************************\\n");
printf("|rec|NO. | name | sc1| sc2| sc3| sum | ave |order|\\n");
while(p!=NULL)
i++;
if(i%10==0)getch();clrscr();
printf("\\n\\n\\n\\n"); /*否则什么也不做*/
else;
printf("|---|----------|---------------|----|----|----|--------|-------|-----|\\n");
printf("|%2d |%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\\n", i, p->no,p->name,p->score[0],p->score[1],
p->score[2],p->sum,p->average,p->order);
p=p->next;

printf("**********************************end*********************************\\n");

/*排序模块*/
STUDENT *sort(STUDENT *h)

int i=0; /*用来保存名次*/
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*断开原来链表头结点与其它结点的连接*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(t->sum<p->sum&&p!=NULL) /*作总分比较*/
q=p; /*待插入点值小,则新表指针后移*/
p=p->next;

if(p==q) /*p==q,上面的while没有执行,也即插入点大于头指针,此点应排在首位*/
t->next=p; /*待排序点的后继为p*/
h=t; /*新头结点为待排序点*/

else /*待排序点应插入在q和p之间,如p为空则是尾部*/
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/


p=h; /*已排好序的头指针赋给p*/
while(p!=NULL) /*赋予各组数据排序号*/

i++; /*结点序号*/
p->order=i; /*将名次赋值*/
p=p->next; /*指针后移*/

printf("Sort sucess!!!\\n"); /*排序成功*/
return (h); /*返回头指针*/

/*查找记录模块*/
void search(STUDENT *h)
STUDENT *p,*q; /*移动指针*/
char s[15]; /*存放姓名的字符数组*/
char t[11];
int x;
printf("***********************************************************\\n");
printf("1.search by name\\n"); /*按姓名查找*/
printf("2.search by No \\n"); /*按学号查找*/
scanf("%d",&x);
clrscr(); /*清屏幕*/
while(x<1||x>2)
printf("\\nplease enter 1 or 2 :");
scanf("%d",&x);
if(x==1)

printf("Input the name that you want to search:\\n");
scanf("%s",s); /*输入姓名*/
p=h; /*将头指针赋给p*/
while(strcmp(p->name,s)&&p!=NULL)/*当记录的姓名不是要找的,并且指针不为空时*/
p=p->next; /*移动指针,指向下一结点,继续查找*/

else
printf("Input the No. that you want to search:\\n");
scanf("%s",t); /*输入学号*/
q=h;
while(strcmp(p->no,t)&&q!=NULL)
q=q->next;
if(p==NULL) /*指针为空,说明未能找到所要的结点*/
printf("\\nCan\'t find the student \\n");
else if(q==NULL) /*指针为空,说明未能找到所要的结点*/
printf("\\nCan\'t find the student \\n");
else /*显示找到的记录信息*/
printf("\\n\\n*****************************havefound***************************\\n");
printf("|NO. | name | sc1| sc2| sc3| sum | ave |order|\\n");
printf("|----------|---------------|----|----|----|--------|-------|-----|\\n");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\\n",
p->no,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);
printf("********************************end*******************************\\n");


/*插入记录模块*/
STUDENT *insert(STUDENT *h)
STUDENT *p,*q,*info,*k; /*p指向插入位置,q是其前驱,info指新插入记录*/
int s1,i,n=0;
printf("\\nplease new record\\n");
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
printf("\\Out of memory"); /*如没有申请到,内存溢出*/
return NULL; /*返回空指针*/

inputs("Enter NO.:",info->no,11); /*以下是待插入数据的录入和处理,具体同创建模块同*/
inputs("Enter name:",info->name,15);
printf("Please input %d score \\n",N);
s1=0;
for(i=0;i<N;i++)
do
printf("score%d:",i+1);
scanf("%d",&info->score[i]);
if(info->score[i]>100||info->score[i]<0)
printf("bad data,repeat input\\n");
while(info->score[i]>100||info->score[i]<0);
s1=s1+info->score[i];

info->sum=s1;
info->average=(float)s1/N;
info->next=NULL; /*设后继指针为空*/
p=h; /*将指针赋值给p*/
q=h; /*将指针赋值给q*/
if(h==NULL) /*链表为空*/
h=info;info->next=NULL;
else
while((info->sum<p->sum)&&(p->next!=NULL))
q=p; /*使q指向p刚才的结点*/
p=p->next; /*使p后移一个结点*/
if(info->sum>=p->sum)
if(h==p)h=info; info->next=p; /*info作为头指针,p作为info的后继指针*/
else q->next=info; /*q的后继指针是info*/
info->next=p; /*info的后继指针是p*/
else
p->next=info;info->next=NULL; /*p的后继指针是info,info的后继指针是空*/
k=h;
while(k!=NULL) /*重新赋予排序号(排序号因为被插入新数据而改变)*/
n++;
k->order=n;
k=k->next;

printf("\\n ----have inserted %s student----\\n",info->name);
return(h); /*返回头指针*/

/*删除记录模块*/
STUDENT *delete(STUDENT *h)
char k[5]; /*定义字符串数组,用来确认删除信息*/
STUDENT *p,*q; /*p为查找到要删除的结点指针,q为其前驱指针*/
char s[11]; /*存放学号*/
clrscr(); /*清屏*/
printf("Please deleted no\\n"); /*显示提示信息*/
scanf("%s",s); /*输入要删除记录的学号*/
q=p=h; /*给q和p赋初值头指针*/
while(strcmp(p->no,s)&&p!=NULL) /*当记录的学号不是要找的,或指针不为空时*/
q=p; /*将p指针值赋给q作为p的前驱指针*/
p=p->next; /*将p指针指向下一条记录*/

if(p==NULL) /*如果p为空,说明链表中没有该结点*/
printf("\\nlist no %s student\\n",s);
else /*p不为空,显示找到的记录信息*/
printf("*****************************have found***************************\\n");
printf("|no | name | sc1| sc2| sc3| sum | ave |order|\\n");
printf("|----------|---------------|----|----|----|--------|-------|-----|\\n");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\\n", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);
printf("********************************end*******************************\\n");
doinputs("Do you really want to deleted?(y/n)",k,5);
while(k[0]!=\'y\'&&k[0]!=\'n\');
if(k[0]!=\'n\') /*删除确认判断*/
if(p==h) /*如果p==h,说明被删结点是头结点*/
h=p->next; /*修改头指针指向下一条记录*/
else
q->next=p->next; /*不是头指针,将p的后继结点作为q的后继结点*/
free(p); /*释放p所指结点空间*/
printf("\\n have deleted No %s student\\n",s);

return(h); /*返回头指针*/

/*统计模块*/
void statistics(STUDENT *h)

STUDENT *p;
int p1,p2,p3,p4;
int m,n,j,k,l,q;
float a1,a2,a3,a4,a5;
m=0;
n=0;
j=0;
k=0,
l=0;
p=h;
printf("Input the score paragraph\\n "); /*输入分数段*/
do

printf("the not pass score : 0~ ");
scanf("%d",&p1);
if(p1<0||p1>100)

printf("wrong data\\n");

while(p1<0||p1>100);
do

printf(" the pass score : %d~",p1);
scanf("%d",&p2);
if(p2<p1||p2>100)

printf("wrong data\\n");

while(p2<p1||p2>100);
do

printf("the general score : %d~",p2);
scanf("%d",&p3);
if(p3<p2||p3>100)

printf("wrong data\\n");

while(p3<p2||p3>100);
do

printf("the well done score :%d~",p3);
scanf("%d",&p4);
if(p4<p3||p4>100)

printf("wrong data\\n");

while(p4<p3||p4>100);
printf("the excellent score :%d~100\\n",p4);
clrscr();
while(p!=NULL)

if(p->average<p1)m++;
else if(p->average<p2)n++;
else if(p->average<p3)j++;
else if(p->average<p4)k++;
else l++;
p=p->next;

q=m+n+j+k+l;
if(q!=0)

a1=(m+0.0)/q*100;
a2=(n+0.0)/q*100;
a3=(j+0.0)/q*100;
a4=(k+0.0)/q*100;
a5=(l+0.0)/q*100;

printf("****************************** Stastics table*********************************\\n");
printf("----------------------------------------------------------------------------- \\n");
printf("|grade| not pass | just pass | general | well done | excellent |\\n");
printf("|-----|-------------|---------------|------------|---------------|------------|\\n");
printf("|score| 0 ~ %d |",p1);
printf(" %d~ %d |",p1,p2);
printf(" %d~ %d |",p2,p3);
printf(" %d~ %d |",p3,p4);
printf(" %d~100 |\\n",p4);
printf("| |(except %d) | (except %d) | (except %d)| (except %d) | |\\n",p1,p2,p3,p4);
printf("|-----|-------------|---------------|------------|---------------|------------|\\n");
printf("|num | %d | %d | %d | %d | %d |\\n",m,n,j,k,l);
printf("|-----|-------------|---------------|----------- |-------------- |------------|\\n");
if(q!=0)
printf("|rate | %3.1f%% |%3.1f%% | %3.1f%% | %3.1f%% | %3.1f%% |\\n",a1,a2,a3,a4,a5);
printf("|-----|-------------|---------------|------------|---------------|------------|\\n");
printf("************************************END***************************************\\n");

/*保存数据到文件模块*/
void save(STUDENT *h)

FILE *fp; /*定义指向文件的指针*/
STUDENT *p; /* 定义移动指针*/
char outfile[20]; /*保存输出文件名*/
printf("Enter outfile name,for example G:\\\\f1\\\\score.txt:\\n");
scanf("%s",outfile);
if((fp=fopen(outfile,"wb"))==NULL) /*为输出打开一个二进制文件,如没有则建立*/

printf("Can not open file\\n");
exit(1);

printf("\\nSaving file......\\n"); /*打开文件,提示正在保存*/
p=h; /*移动指针从头指针开始*/
while(p!=NULL) /*如p不为空*/

fwrite(p,sizeof(STUDENT),1,fp); /*写入一条记录*/
p=p->next; /*指针后移*/

fclose(fp); /*关闭文件*/
printf("-----Save success!!-----\\n"); /*显示保存成功*/

/*导入信息模块*/
STUDENT *load()
STUDENT *p,*q,*h=NULL; /*定义记录指针变量*/
FILE *fp; /* 定义指向文件的指针*/
char infile[20]; /*保存文件名*/
printf("Enter infile name,for example G:\\\\f1\\\\score.txt:\\n");
scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"rb"))==NULL) /*打开一个二进制文件,为读方式*/
printf("Can not open file\\n"); /*如不能打开,返回头指针*/
return h;

printf("\\n -----Loading file!-----\\n");
p=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!p)
printf("Out of memory!\\n"); /*如没有申请到,则内存溢出*/
return h; /*返回空头指针*/

h=p; /*申请到空间,将其作为头指针*/
while(!feof(fp)) /*循环读数据直到文件尾结束*/
if(1!=fread(p,sizeof(STUDENT),1,fp))
break; /*如果没读到数据,跳出循环*/
p->next=(STUDENT *)malloc(sizeof(STUDENT)); /*为下一个结点申请空间*/
if(!p->next)

printf("Out of memory!\\n"); /*如没有申请到,则内存溢出*/
return h;

q=p; /*保存当前结点的指针,作为下一结点的前驱*/
p=p->next; /*指针后移,新读入数据链到当前表尾*/

q->next=NULL; /*最后一个结点的后继指针为空*/
fclose(fp); /*关闭文件*/
printf("Load success!!!\\n");
return h; /*返回头指针*/

/******主函数开始*******/
main()
int i;
STUDENT *head; /*链表定义头指针*/
head=init(); /*初始化链表*/
clrscr(); /*清屏*/
for(;;) /*无限循环*/
switch(menu_select()) /*调用主菜单函数,返回值整数作开关语句的条件*/

case 0:head=init();break; /*执行初始化*/
case 1:head=create();break; /*创建链表*/
case 2:print(head);break; /*显示全部记录*/
case 3:head=sort(head);break; /*排序*/
case 4:search(head);break; /*查找记录*/
case 5:head=insert(head); break; /*插入记录*/
case 6:head=delete(head);break; /*删除记录*/
case 7:save(head);break; /*保存文件*/
case 8:head=load(); break; /*读文件*/
case 9:statistics(head); break; /*统计*/
case 10:exit(0); /*如菜单返回值为10程序结束*/


参考技术A 我给你做,给你调试了一下,没问题的
学生的个数可以通过N来进行直接修改,有问题可以找我
#include<stdio.h>
#include<string.h>
#define N 3//定义学生的个数
struct student//学生的结构体

int num;
char name[8];
int yuwen;
int shuxue;
int yingyu;
int wuli;

st[N];
void main()

int i,j;
double avr[N];
struct student t;
//用于后面做冒泡排序时的中间变量
printf("输入%d名学生的相关信息:\n",N);
//N是你在前面用宏定义的
//你要输入几个学生的信息改变N值就可以了
printf("**************************************************\n");
printf("学号 姓名 语文 数学 英语 物理\n");
for(i=0;i<N;i++)
scanf("%d%s%d%d%d%d",&st[i].num,st[i].name,&st[i].yuwen,&st[i].shuxue,&st[i].yingyu,&st[i].wuli);
printf("**************************************************\n");
printf("学号 姓名 平均分\n");
for(i=0;i<N;i++)

avr[i]=(st[i].yuwen+st[i].shuxue+st[i].yingyu+st[i].wuli)/4.0;
printf("%d\t\t%s\t%.2lf",st[i].num,st[i].name,avr[i]);
//注意这里的.2lf是说保留两位小数的格式描述符.2的意思是几位小数位
printf("\n");

printf("输入你要查询学生的序号,是第几个学生\n");
scanf("%d",&i);
printf("学号 姓名 语文 数学 英语 物理\n");
printf("%d\t\t%s %d %d %d %d\n",st[i-1].num,st[i-1].name,st[i-1].yuwen,st[i-1].shuxue,st[i-1].yingyu,st[i-1].wuli);
//这是用来选择你要排序的种类的,注意是中文的输入
printf("按照平均成绩进行排序:\n");
printf("**************************************************\n");
//下面是冒泡排序
//例如按照平均成绩排序
for(i=0;i<N-1;i++)
for(j=0;j<N-i-1;j++)
if(avr[j]<=avr[j+1])

t=st[j];
st[j]=st[j+1];
st[j+1]=t;

printf("学号 姓名 语文 数学 英语 物理\n");
for(i=0;i<N;i++)
printf("%d\t\t%s %d %d %d %d\n",st[i].num,st[i].name,st[i].yuwen,st[i].shuxue,st[i].yingyu,st[i].wuli);
getchar();
参考技术B 看起来不难啊,可惜没时间,不然做个就当练习编程了

以上是关于解答一个C语言程序的主要内容,如果未能解决你的问题,请参考以下文章

c语言数据类型异常,请牛人解答

c语言程序解答(在线等)?

c语言中求交集的一个函数,不知道哪里错了,求高手解答。。。

求解答C语言“指针赋值”?

c语言背包问题,求高手解答

求解答c语言结构体定义中typedef的作用