中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx

上传人:b****2 文档编号:4164045 上传时间:2023-05-02 格式:DOCX 页数:15 大小:67.66KB
下载 相关 举报
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第1页
第1页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第2页
第2页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第3页
第3页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第4页
第4页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第5页
第5页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第6页
第6页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第7页
第7页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第8页
第8页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第9页
第9页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第10页
第10页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第11页
第11页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第12页
第12页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第13页
第13页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第14页
第14页 / 共15页
中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx_第15页
第15页 / 共15页
亲,该文档总共15页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx

《中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx》由会员分享,可在线阅读,更多相关《中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx(15页珍藏版)》请在冰点文库上搜索。

中国石油大学华东C语言在线测评答案 第12章结构体和共用体级亲测正确Word文件下载.docx

scanf("

%f"

&

a);

fun(___3___,a);

show(std);

return0;

/*PRESETCODEBEGIN-NEVERTOUCHCODEBELOW*/

#include<

stdio.h>

string.h>

typedefstruct

intnum;

charname[9];

floatscore[3];

}STU;

voidshow(STUtt)

printf("

%d%s:

"

tt.num,tt.name);

%5.1f"

tt.score[i]);

\n"

);

/*PRESETCODEEND-NEVERTOUCHCODEABOVE*/

voidfun(STU*ss,floata)

score[i]*=a;

intmain()

fun(&

std,a);

12.2修改学生信息

程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。

函数fun的功能是对形参b所指结构体变量中的数据进行修改,最后在主函数中输出修改后的数据。

例如:

b所指变量t中的学号、姓名、和三门课的成绩依次是:

*****、"

ZhangQi"

、93、85、87,修改后输出t中的数据应为:

LiJie"

、93、85、87。

请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。

不得增行或删行,也不得更改程序的结构!

只需提交补充完整的fun函数和main主函数

voidfun(structstudent 

*b)

{

b__1__=10004;

strcpy(b__2__,"

LiJie"

intmain()

structstudent 

t={10002,"

{93,85,87}};

int 

i;

fun(__3__);

No:

%ld 

Name:

%s\nScores:

"

t.sno,t.name);

for(i=0;

i++) 

%6.2f"

t.score[i]);

structstudent

longsno;

charname[10];

};

voidfun(structstudent*b)

b->

sno=10004;

strcpy(b->

name,"

structstudentt={10002,"

t);

%ldName:

i++)printf("

12.3学生信息的排序

程序通过定义学生结构体数组,存储了若干名学生的学号、姓名和3门课的成绩。

函数fun的功能是将存放学生数据的结构体数组,按照姓名的字典序(从小到大)排序。

只需提交补充完整的fun函数。

voidfun(structstudent 

a[],int 

n)

__1__t;

i,j;

__2__;

for(j=i+1;

j<

n;

j++)

if(strcmp(__3__)>

0)

t=a[i];

a[i]=a[j];

a[j]=t;

}

structstudent

voidfun(structstudenta[],intn)

structstudentt;

inti,j;

n-1;

if(strcmp(a[i].name,a[j].name)>

{t=a[i];

12.4找出指定分数范围内的学生

学生的记录由学号和成绩组成,N名学生的数据已在主函数中放入结构体数组s中,请编写函数fun,它的功能是:

把指定分数范围内的学生数据放在h所指的数组中,分数范围内的学生人数由函数值返回。

例如,输入的分数是6069,则应当把分数在60到69的学生数据进行输出,包含60分和69分的学生数据。

主函数中将把60放在low中,把69放在heigh中。

只需提交fun函数

STRECs[N]={{"

GA005"

85},{"

GA003"

76},{"

GA002"

69},{"

GA004"

GA001"

96},{"

GA007"

72},{"

GA008"

64},{"

GA006"

87},{"

GA015"

GA013"

94},{"

GA012"

GA014"

91},{"

GA011"

90},{"

GA017"

GA018"

GA016"

72}};

12.5找出分数最低的学生

把分数最低的学生数据放在b所指的数组中,注意:

分数最低的学生可能不止一个,函数返回分数最低的学生的人数。

注意:

只需提交fun函数

#defineN16

charnum[10];

ints;

}STREC;

intfun(STRECs[],STRECh[])

intj,min,count=0;

min=s[0].s;

for(j=1;

j<

N;

j++)

{

if(s[j].s<

min)

{

min=s[j].s;

}

for(j=0;

if(s[j].s==min)

h[count]=s[j];

count++;

returncount;

STRECs[N]={{"

GA05"

GA03"

GA02"

GA04"

GA01"

GA07"

GA08"

GA06"

STRECh[N];

inti,n;

n=fun(s,h);

i<

%s%4d\n"

h[i].num,h[i].s);

12.6求平面上两点距离

编写程序,计算二维平面上两点p1和p2间的直线距离。

输入:

两点的坐标值输出:

两点的距离注意:

#include"

math.h"

doublex,y;

}POINT2D;

doublefun(POINT2Dp1,POINT2Dp2)

doublem=0;

m=(p2.x-p1.x)*(p2.x-p1.x);

m+=(p2.y-p1.y)*(p2.y-p1.y);

m=(double)(sqrt(m));

returnm;

POINT2Dp1,p2;

doublee;

%lf%lf"

p1.x,&

p1.y);

p2.x,&

p2.y);

e=fun(p1,p2);

%lf\n"

e);

12.7加密

编写程序,按下表所示的码表将明文中指定的明码转换为暗码(其他字符不变),形成密文并输出。

明文输出:

与输入相对应的密文注意:

#defineN80

charreal;

/*明码*/

charcode;

/*密码*/

}ENCODE;

voidfun(chars[],chart[],ENCODEtab[])

inti=0,j,find;

while(s[i]!

='

\0'

find=0;

for(j=0;

4;

if(s[i]==tab[j].real)

t[i]=tab[j].code;

find=1;

break;

if(find==0)t[i]=s[i];

i++;

t[i]='

;

chars[N],t[N];

ENCODEtab[]={{'

a'

'

d'

},{'

b'

z'

}};

/*定义码表,供转换时查阅*/

gets(s);

fun(s,t,tab);

%s\n"

t);

}/*PRESETCODEEND-NEVERTOUCHCODEABOVE*/

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 医药卫生 > 基础医学

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2