- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
请用冒泡法重做此题 #include stdio.h typedef struct Student { int num; char name[20]; float score; }Stu; void sort(Stu a[],int n) { int i,j; Stu temp; for (j=0;jn-1;j++) { for (i=0;in-1-j;i++) { if(a[i].scorea[i+1].score) { temp=a[i];a[i]=a[i+1];a[i+1]=temp; } } } } int main() { Stu s[3]={{101,Li,89},{101,Sun,100},{101,Yang,92}}; int i; sort(s,3); for (i=0;i3;i++) printf(%d\t%s\t%f\n,s[i].num,s[i].name,s[i].score); return 0; } #include stdio.h #include stdlib.h typedef struct Student { int num; char name[20]; float score; }Stu; int lessthan(const void *a, const void *b) { Stu *s1=(Stu*)a; Stu *s2=(Stu*)b; return (*s1).score(*s2).score; //return s1-scores2-score; } int main() { Stu s[3]= {{101,Li,89},{101,Sun,100},{101,Yang,92}}; int i; qsort(s,3,sizeof(s[0]),lessthan); for (i=0;i3;i++) printf(%d\t%s\t%f\n,s[i].num,s[i].name,s[i].score); return 0; } 上题中print中形式参数为struct,会有结构体变量的复制,如改为指针传递,程序运行速度会更快,占用内存更小。 请同学们将修改max和print,改为指针传递。 do while的for等价形式 for (p=head;p!=NULL;p=p-next) { printf(%d\t%f\n,p-num,p-score); } 解题思路: 如果job项为s,则第5项为class。即Li是501班的。如果job项是t,则第5项为position。Wang是prof(教授)。 解题思路: 对第5项可以用共用体来处理(将class和position放在同一段存储单元中) #include stdio.h struct { int num; char name[10]; char sex; char job; union { int clas; char position[10]; }category; }person[2]; 外部的结构体数组 共用体变量 #include stdio.h union Categ { int clas; char position[10]; }; struct { int num; char name[10]; char sex; char job; union Categ category }person[2]; 声明共用体类型 定义共用体类型变量 int main() {int i; for(i=0;i2;i++) {scanf(%d %s %c %c“,person[i].num, person[i].name, person[i].sex,person[i].job); if(person[i].job == s) scanf(%d“,person[i].category.clas); else if(person[i].job == t‘) scanf(“%s”,person[i].category.position);
您可能关注的文档
最近下载
- 下肢深静脉血栓形成的预防宣教.pptx VIP
- 天-猫-保-健-食-品-行-业-标-准复习进程.docx VIP
- 2025高考数学核心二级结论速记指南.pdf VIP
- 整理收纳讲座-整理收纳术.pptx VIP
- 中山建设工程造价指数指标2017-中山住房和城乡建设局政务网.PDF
- 提升幸福感的整理收纳术 日常生活劳动通用八年级全册整理与收纳.pptx VIP
- 高中政治统编版必修一中国特色社会主义第二课只有社会主义才能救中国测试题.pdf VIP
- 新能源汽车维护与保养学习单元2-2驱动及冷却系统维护与保养.pptx VIP
- TCECS-铁路工程采空区防治技术规程.pdf VIP
- 齐齐哈尔市教管育理学会“十二五”课题申报评审书.doc VIP
文档评论(0)