c语言 12 - 4
1、
1.1
#include <stdio.h> #include <string.h> #define NUMBER 5 #define NAME_LEN 64 typedef struct{ char name[NAME_LEN]; int height; float weight; long schols; }Student; void swap(Student *x, Student *y) { Student tmp = *x; *x = *y; *y = tmp; } void sort(Student x[], int n) { int i, j; for(i = 0; i < n - 1; i++) { for(j = n - 1; j > i; j--) { if(x[j - 1].height > x[j].height) { swap(&x[j - 1], &x[j]); } } } } int main(void) { int i; Student stu[NUMBER]; for(i = 0; i < NUMBER; i++) { printf("NO.%d.name = ", i + 1); scanf("%s", stu[i].name); printf("NO.%d.height = ", i + 1); scanf("%d", &stu[i].height); printf("NO.%d.weight = ", i + 1); scanf("%f", &stu[i].weight); printf("NO.%d.schols = ", i + 1); scanf("%ld", &stu[i].schols); } for(i = 0; i < NUMBER; i++) { printf("%-8s %7d %7.2f %7ld\n", stu[i].name, stu[i].height, stu[i].weight, stu[i].schols); } sort(stu, NUMBER); puts("\n================================\n"); for(i = 0; i < NUMBER; i++) { printf("%-8s %7d %7.2f %7ld\n", stu[i].name, stu[i].height, stu[i].weight, stu[i].schols); } return 0; }
1.2
#include <stdio.h> #include <string.h> #define NUMBER 5 #define NAME_LEN 64 typedef struct{ char name[NAME_LEN]; int height; float weight; long schols; }Student; void swap(Student *x, Student *y) { Student tmp = *x; *x = *y; *y = tmp; } void sort_int(Student x[], int n) { int i, j; for(i = 0; i < n - 1; i++) { for(j = n - 1; j > i; j--) { if(x[j - 1].height > x[j].height) { swap(&x[j - 1], &x[j]); } } } } void sort_str(Student x[], int n) { int i, j; for(i = 0; i < n - 1; i++) { for(j = n - 1; j > i; j--) { if(strcmp(x[j - 1].name,x[j].name) > 0) { swap(&x[j - 1], &x[j]); } } } } int main(void) { int i; Student stu[NUMBER]; for(i = 0; i < NUMBER; i++) { printf("NO.%d.name = ", i + 1); scanf("%s", stu[i].name); printf("NO.%d.height = ", i + 1); scanf("%d", &stu[i].height); printf("NO.%d.weight = ", i + 1); scanf("%f", &stu[i].weight); printf("NO.%d.schols = ", i + 1); scanf("%ld", &stu[i].schols); } for(i = 0; i < NUMBER; i++) { printf("%-8s %7d %7.2f %7ld\n", stu[i].name, stu[i].height, stu[i].weight, stu[i].schols); } int j; puts("choose: j = 1, sort by height; j = 2, sort by name."); printf("j = "); scanf("%d", &j); switch(j) { case 1: sort_int(stu, NUMBER); break; case 2: sort_str(stu, NUMBER); break; } puts("\n================================\n"); for(i = 0; i < NUMBER; i++) { printf("%-8s %7d %7.2f %7ld\n", stu[i].name, stu[i].height, stu[i].weight, stu[i].schols); } return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律