实验6

task4

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

 

image

 task5

 1 #include<stdio.h>
 2 
 3 typedef struct{
 4     int year;
 5     int month;
 6     int day;
 7 } Date;
 8 
 9 // 函数声明
10 void input(Date *pd);                    // 输入日期给pd指向的Date变量
11 int day_of_year(Date d);                // 返回日期d是这一年的第多少天
12 int compare_dates(Date d1, Date d2);    // 比较两个日期:
13                                         // 如果d1在d2之前,返回-1;
14                                         // 如果d1在d2之后,返回1
15                                         // 如果d1和d2相同,返回0
16  
17 void test1(){
18     Date d;
19     int i;
20     
21     printf("输入日期:(以形如2025-12-19这样的形式输入)\n");
22     for(i = 0; i < 3; ++i){
23         input(&d);
24         printf("%d-%02d-%02d是这一年中第%d天\n\n", d.year, d.month, d.day, day_of_year(d));
25     }
26 } 
27 
28 void test2(){
29     Date Alice_birth, Bob_birth;
30     int i;
31     int ans;
32     
33     printf("输入Alice和Bob出生日期:(以形如2025-12-19这样的形式输入)\n");
34     for(i = 0; i < 3; ++i){
35         input(&Alice_birth);
36         input(&Bob_birth);
37         ans = compare_dates(Alice_birth, Bob_birth);
38         
39         if(ans == 0)
40             printf("Alice和Bob一样大\n\n");
41         else if(ans == -1)
42             printf("Alice比Bob大\n\n");
43         else 
44             printf("Alice比Bob小\n\n");
45     }
46 }
47 
48 int main(){
49     printf("测试1: 输入日期, 打印输出这是一年中第多少天\n");
50     test1();
51     
52     printf("\n测试2: 两个人年龄大小关系\n");
53     test2();               
54 }
55 
56 void input(Date *pd){
57     scanf("%d-%d-%d", &(pd->year), &(pd->month), &(pd->day));
58 }
59 
60 int day_of_year(Date d){
61     int mon[] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
62     int total = 0;
63     int Run = (d.year % 4 == 0 && d.year % 100 != 0) || (d.year % 400 == 0);
64     
65     for(int i = 0; i < d.month - 1; i++){
66         total += mon[i];
67     }
68     if(Run && d.month > 2){
69         total += 1;
70     }
71     total += d.day;
72     
73     return total;
74 }
75 
76 int compare_dates(Date d1, Date d2){
77     if (d1.year < d2.year) {
78         return -1; 
79     } 
80     else if (d1.year > d2.year) {
81         return 1;  
82     }
83     
84     if (d1.month < d2.month) {
85         return -1; 
86     } 
87     else if (d1.month > d2.month) {
88         return 1;  
89     }
90     
91     if (d1.day < d2.day) {
92         return -1; 
93     } 
94     else if (d1.day > d2.day) {
95         return 1; 
96     }
97     
98     return 0;
99 }

image

 task6

 1 #include <stdio.h>
 2 #include <string.h>
 3 
 4 enum Role {admin, student, teacher};
 5 
 6 typedef struct{
 7     char username[20];
 8     char password[20];
 9     enum Role type;
10 } Account;
11 
12 void output(Account x[], int n);  // 输出账户数组x中n个账户信息,其中,密码用*替代显示
13 
14 int main(){
15     Account x[] = {{"A1001", "123456", student},
16                     {"A1002", "123abcdef", student},
17                     {"A1009", "xyz12121", student}, 
18                     {"X1009", "9213071x", admin},
19                     {"C11553", "129dfg32k", teacher},
20                     {"X3005", "921kfmg917", student}};
21     int n;
22     n = sizeof(x)/sizeof(Account);
23     output(x, n);
24     
25     return 0;
26 }
27 
28 void output(Account x[], int n){
29     for(int i = 0; i < n; i++){
30         printf("%-10s", x[i].username);
31         int pwd_len = strlen(x[i].password);
32         for(int j = 0; j < pwd_len; j++){
33             printf("*");
34         }
35         printf("\t");
36         
37         switch(x[i].type){
38             case admin:
39                 printf("admin");
40                 break;
41             case student:
42                 printf("student");
43                 break;
44             case teacher:
45                 printf("teacher");
46                 break;
47             default:
48                 printf("unknown");
49         }
50         printf("\n");
51     }
52 }

image

 task7

 1 #include <stdio.h>
 2 #include <string.h>
 3 
 4 typedef struct {
 5     char name[20];   // 姓名
 6     char phone[12];  // 手机号
 7     int vip;         // 是否为紧急联系人,是取1;否则取0
 8 } Contact;
 9 
10 // 函数声明
11 void set_vip_contact(Contact x[], int n, char name[]); // 设置紧急联系人
12 void output(Contact x[], int n);                       // 输出x中联系人信息
13 void display(Contact x[], int n);                      // 按姓名字典序+紧急优先显示
14 
15 #define N 10
16 
17 int main() {
18     Contact list[N] = {{"刘一", "15510846604", 0},
19                        {"陈二", "18038747351", 0},
20                        {"张三", "18853253914", 0},
21                        {"李四", "13230584477", 0},
22                        {"王五", "15547571923", 0},
23                        {"赵六", "18856659351", 0},
24                        {"周七", "17705843215", 0},
25                        {"孙八", "15552933732", 0},
26                        {"吴九", "18077702405", 0},
27                        {"郑十", "18820725036", 0}};
28     int vip_cnt, i;
29     char name[20];
30 
31     printf("显示原始通讯录信息:\n");
32     output(list, N);
33 
34     printf("\n输入要设置的紧急联系人个数:");
35     scanf("%d", &vip_cnt);
36     printf("输入%d个紧急联系人姓名:\n", vip_cnt);
37     for(i = 0; i < vip_cnt; ++i) {
38         scanf("%s", name);
39         set_vip_contact(list, N, name);
40     }
41 
42     printf("\n显示通讯录列表:(按姓名字典序升序排列, 紧急联系人最先显示)\n");
43     display(list, N);
44 
45     return 0;
46 }
47 
48 // 补全set_vip_contact函数:将姓名匹配的联系人设为紧急联系人(vip=1)
49 void set_vip_contact(Contact x[], int n, char name[]) {
50     for (int i = 0; i < n; i++) {
51         if (strcmp(x[i].name, name) == 0) {
52             x[i].vip = 1;
53         }
54     }
55 }
56 
57 // 补全display函数:按“紧急优先+姓名字典序”排序后输出
58 void display(Contact x[], int n) {
59     
60     Contact temp;
61     for (int i = 0; i < n - 1; i++) {
62         for (int j = 0; j < n - i - 1; j++) {
63          
64             if (x[j].vip < x[j+1].vip) {
65                 temp = x[j];
66                 x[j] = x[j+1];
67                 x[j+1] = temp;
68             }
69           
70             else if (x[j].vip == x[j+1].vip) {
71                 if (strcmp(x[j].name, x[j+1].name) > 0) {
72                     temp = x[j];
73                     x[j] = x[j+1];
74                     x[j+1] = temp;
75                 }
76             }
77         }
78     }
79     
80     output(x, n);
81 }
82 
83 
84 void output(Contact x[], int n) {
85     int i;
86     
87     for(i = 0; i < n; ++i) {
88         printf("%-10s%-15s", x[i].name, x[i].phone);
89         if(x[i].vip)
90             printf("%5s", "*");
91         printf("\n");
92     }
93 }

image

 

posted @ 2025-12-25 20:07  屑乃  阅读(3)  评论(0)    收藏  举报