实验6 C语言结构体和枚举应用编程

实验任务4:

源代码:

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #define N 10
 4 
 5 typedef struct {
 6     char isbn[20];    
 7     char name[80];    
 8     char author[80];  
 9     double sales_price;
10     int sales_count;  
11 } Book;
12 void output(Book x[], int n);
13 void sort(Book x[], int n);
14 double sales_amount(Book x[], int n);
15 int main() {
16     Book x[N] = {
17         {"978-7-5327-6082-4","门将之死","罗纳德.伦",42,51},
18         {"978-7-308-17047-5","自由与爱之地:入以色列记","云也退",49,30},
19         {"978-7-5404-9344-8","伦敦人","克莱格泰勒",68,27},
20         {"978-7-5447-5246-6","软件体的生命周期","特德姜", 35, 90},
21         {"978-7-5722-5475-8","芯片简史","汪波",74.9,49},
22         {"978-7-5133-5750-0","主机战争","布莱克.J.哈里斯",128,42},
23         {"978-7-2011-4617-1","世界尽头的咖啡馆","约翰·史崔勒基",22.5,44},
24         {"978-7-5133-5109-6","你好外星人","英国未来出版集团",118,42},
25         {"978-7-1155-0509-5","无穷的开始:世界进步的本源","戴维·多伊奇",37.5,55},
26         {"978-7-229-14156-1","源泉","安.兰德",84,59}
27     };
28 
29     printf("图书销量排名(按销售册数): \n");
30     sort(x, N);
31     output(x, N);
32     printf("\n图书销售总额: %.2f\n", sales_amount(x, N));
33 
34     system("pause");
35     return 0;
36 }
37 void output(Book x[], int n) {
38     for (int i = 0; i < n; i++) {
39         printf("%-20s %-30s %-20s %-8.2f %-6d\n",
40             x[i].isbn, x[i].name, x[i].author, x[i].sales_price, x[i].sales_count);
41     }
42 }
43 void sort(Book x[], int n) {
44     int i, j;
45     Book temp;
46     for (i = 0; i < n - 1; i++) {
47         for (j = 0; j < n - 1 - i; j++) {
48             if (x[j].sales_count < x[j + 1].sales_count) {
49                 temp = x[j];
50                 x[j] = x[j + 1];
51                 x[j + 1] = temp;
52             }
53         }
54     }
55 }
56 double sales_amount(Book x[], int n) {
57     double sum = 0.0;
58     for (int i = 0; i < n; i++) {
59         sum += x[i].sales_price * x[i].sales_count;
60     }
61     return sum;
62 }

运行截图:

4444

 

实验任务5:

源代码:

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 typedef struct {
 4     int year;
 5     int month;
 6     int day;
 7 } Date;
 8 void input(Date* pd);
 9 int day_of_year(Date d);
10 int compare_dates(Date d1, Date d2);
11 
12 void test1() {
13     Date d;
14     int i;
15     printf("输入日期:(以形如2025-12-19这样的形式输入)\n");
16     for (i = 0; i < 3; ++i) {
17         input(&d);
18         printf("%d-%02d-%02d是这一年中第%d天\n\n",
19             d.year, d.month, d.day, day_of_year(d));
20     }
21 }
22 void test2() {
23     Date Alice_birth, Bob_birth;
24     int i;
25     int ans;
26     printf("输入Alice和Bob出生日期:(以形如2025-12-19这样的形式输入)\n");
27     for (i = 0; i < 3; ++i) {
28         input(&Alice_birth);
29         input(&Bob_birth);
30         ans = compare_dates(Alice_birth, Bob_birth);
31         if (ans == 0)
32             printf("Alice和Bob一样大\n\n");
33         else if (ans == -1)
34             printf("Alice比Bob大\n\n");
35         else
36             printf("Alice比Bob小\n\n");
37     }
38 }
39 int main() {
40     printf("测试1: 输入日期, 打印输出这是一年中第多少天\n");
41     test1();
42     printf("\n测试2: 两个人年龄大小关系\n");
43     test2();
44     system("pause");
45     return 0;
46 }
47 void input(Date* pd) {
48     scanf_s("%d-%d-%d", &pd->year, &pd->month, &pd->day);
49 }
50 int isLeap(int y) {
51     if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0))
52         return 1;
53     return 0;
54 }
55 int day_of_year(Date d) {
56     int days[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
57     int sum = 0;
58     if (isLeap(d.year))
59         days[2] = 29;
60 
61     for (int i = 1; i < d.month; i++) {
62         sum += days[i];
63     }
64     sum += d.day;
65     return sum;
66 }
67 int compare_dates(Date d1, Date d2) {
68     if (d1.year != d2.year) {
69         return d1.year < d2.year ? -1 : 1;
70     }
71     if (d1.month != d2.month) {
72         return d1.month < d2.month ? -1 : 1;
73     }
74     if (d1.day != d2.day) {
75         return d1.day < d2.day ? -1 : 1;
76     }
77     return 0;
78 }

运行截图:

5555555555

 

实验任务6:

源代码:

 1 #define _CRT_SECURE_NO_WARNINGS
 2 #include <stdio.h>
 3 #include <string.h>
 4 #include <stdlib.h>
 5 enum Role { admin, student, teacher };
 6 typedef struct {
 7     char username[20];  
 8     char password[20];   
 9     enum Role type;    
10 } Account;
11 void output(Account x[], int n);
12 int main() {
13     Account x[] = {
14         {"A1001", "123456", student},
15         {"A1002", "123abcdef", student},
16         {"A1009", "xyz12121", student},
17         {"X1009", "9213071x", admin},
18         {"C11553", "129dfg32k", teacher},
19         {"X3005", "921kfmg917", student}
20     };
21     int n = sizeof(x) / sizeof(Account);
22     output(x, n);
23     system("pause");
24     return 0;
25 }
26 void output(Account x[], int n) {
27     for (int i = 0; i < n; i++) {
28         printf("%-10s ", x[i].username);
29         int len = strlen(x[i].password);
30         for (int j = 0; j < len; j++) {
31             printf("*");
32         }
33         for (int j = len; j < 12; j++) {
34             printf(" ");
35         }
36         printf(" "); 
37         switch (x[i].type) {
38         case admin:
39             printf("%-8s\n", "admin");
40             break;
41         case student:
42             printf("%-8s\n", "student");
43             break;
44         case teacher:
45             printf("%-8s\n", "teacher");
46             break;
47         }
48     }
49 }

运行截图:

6666666666666666

 

实验任务7:

源代码:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct {
    char name[20];   
    char phone[12];  
    int vip;         
} Contact;
#define N 10
void set_vip_contact(Contact x[], int n, char name[]);
void output(Contact x[], int n);
void display(Contact x[], int n);
// 辅助排序:按姓名字典序
void sortByName(Contact arr[], int len);
int main() {
    Contact list[N] = {
        {"刘一", "15510846604", 0},
        {"陈二", "18038747351", 0},
        {"张三", "18853253914", 0},
        {"李四", "13230584477", 0},
        {"王五", "15547571923", 0},
        {"赵六", "18856659351", 0},
        {"周七", "17705843215", 0},
        {"孙八", "15552933732", 0},
        {"吴九", "18077702405", 0},
        {"郑十", "18820725036", 0}
    };
    int vip_cnt, i;
    char name[20];
    printf("显示原始通讯录信息: \n");
    output(list, N);
    printf("\n输入要设置的紧急联系人个数: ");
    scanf("%d", &vip_cnt);
    printf("输入%d个紧急联系人姓名:\n", vip_cnt);
    for (i = 0; i < vip_cnt; ++i) {
        scanf("%s", name);
        set_vip_contact(list, N, name);
    }
    printf("\n显示通讯录列表:(按姓名字典序升序排列,紧急联系人最先显示)\n");
    display(list, N);
    system("pause");
    return 0;
}
void set_vip_contact(Contact x[], int n, char name[]) {
    for (int i = 0; i < n; i++) {
        if (strcmp(x[i].name, name) == 0) {
            x[i].vip = 1;
        }
    }
}
void output(Contact x[], int n) {
    int i;
    for (i = 0; i < n; ++i) {
        printf("%-10s%-15s", x[i].name, x[i].phone);
        if (x[i].vip)
            printf("   *");
        printf("\n");
    }
}
void sortByName(Contact arr[], int len) {
    int i, j;
    Contact temp;
    for (i = 0; i < len - 1; i++) {
        for (j = 0; j < len - 1 - i; j++) {
            if (strcmp(arr[j].name, arr[j + 1].name) > 0) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}
void display(Contact x[], int n) {
    Contact temp[N];
    int idx = 0;
    for (int i = 0; i < n; i++) {
        if (x[i].vip == 1) {
            temp[idx++] = x[i];
        }
    }
    for (int i = 0; i < n; i++) {
        if (x[i].vip == 0) {
            temp[idx++] = x[i];
        }
    }
    sortByName(temp, n);
    for (int i = 0; i < n; i++) {
        printf("%-10s%-15s", temp[i].name, temp[i].phone);
        if (temp[i].vip)
            printf("   *");
        printf("\n");
    }
}

运行截图:

7777777777777777

 

posted @ 2026-06-15 17:17  rjyyy  阅读(0)  评论(0)    收藏  举报