首页 > 编程语言 >实验6 c语言结构体、枚举应用编程

实验6 c语言结构体、枚举应用编程

时间:2023-12-12 16:24:52浏览次数:51  
标签:int 编程 year sales 枚举 实验 printf d2 day

实验任务4

程序源码

 1 #include <stdio.h>
 2 #define N 10
 3 
 4 typedef struct {
 5     char isbn[20];          // isbn号
 6     char name[80];          // 书名
 7     char author[80];        // 作者
 8     double sales_price;     // 售价
 9     int  sales_count;       // 销售册数
10 } Book;
11 
12 void output(Book x[], int n);
13 void sort(Book x[], int n);
14 double sales_amount(Book x[], int n);
15 
16 int main() {
17     Book x[N] = {{"978-7-229-14156-1", "源泉", "安.兰德", 84, 59},
18                  {"978-7-5133-5261-1", "李白来到旧金山", "谭夏阳", 48, 16},
19                  {"978-7-5617-4347-8", "陌生人日记", "周怡芳", 72.6, 27},
20                  {"978-7-5722-5475-8", "芯片简史", "汪波", 74.9, 49},
21                  {"978-7-5046-9568-0", "数据化决策", "道格拉斯·W·哈伯德", 49, 42},
22                  {"978-7-5133-4388-6", "美好时代的背后", "凯瑟琳.布", 34.5, 39},
23                  {"978-7-1155-0509-5", "无穷的开始:世界进步的本源", "戴维·多伊奇", 37.5, 55},
24                  {"978-7-5321-5691-7", "何为良好生活", "陈嘉映", 29.5 , 31},
25                  {"978-7-5133-5109-6", "你好外星人", "英国未来出版集团", 118, 42},
26                  {"978-7-2011-4617-1", "世界尽头的咖啡馆", "约翰·史崔勒基", 22.5, 44}};
27     
28     printf("图书销量排名: \n");
29     sort(x, N);
30     output(x, N);
31 
32     printf("\n图书销售总额: %.2f\n", sales_amount(x, N));
33     
34     return 0;
35 }
36 
37 // 待补足:函数output()实现
38 // ×××
39 void output(Book x[], int n){
40     int i;
41     printf("ISBN号              书名                          作者               售价       销售册数\n");
42     for(i = 0; i < n; i++){
43         if(x[i].sales_price == (int)x[i].sales_price){
44         printf("%-20s%-30s%-20s%-10.0f%-5d\n",x[i].isbn, x[i].name, x[i].author, x[i].sales_price , x[i].sales_count);    
45         }
46         else
47         printf("%-20s%-30s%-20s%-10.1f%-5d\n",x[i].isbn, x[i].name, x[i].author, x[i].sales_price , x[i].sales_count);
48     }
49 }
50 
51 // 待补足:函数sort()实现
52 // ×××
53 void sort(Book x[], int n){
54     int i, j;
55     Book mid;
56     for(i = 0; i < n - 1; i++){
57         for(j = 0; j < n - 1 - i; j++){
58             if(x[j].sales_count < x[j+1].sales_count){
59                 mid = x[j + 1];
60                 x[j + 1] = x[j];
61                 x[j] = mid;
62             }
63         }
64     }
65 }
66 
67 // 待补足:函数sales_count()实现
68 // ×××
69 double sales_amount(Book x[], int n){
70     int i;
71     double sum = 0.0;
72     for(i = 0; i < n; i++){
73         sum += x[i].sales_price * x[i].sales_count;
74     }
75     return sum;
76 }
View Code

运行结果截图

 实验任务5

程序源码

  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("输入日期:(以形如2023-12-11这样的形式输入)\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出生日期:(以形如2023-12-11这样的形式输入)\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 // 补足函数input实现
 57 // 功能: 输入日期给pd指向的Date变量
 58 void input(Date *pd) {
 59     scanf("%d-%d-%d", &pd->year, &pd->month, &pd->day);
 60 }
 61 
 62 // 补足函数day_of_year实现
 63 // 功能:返回日期d是这一年的第多少天
 64 int day_of_year(Date d) {
 65     int n, j, k, flag;
 66     int i = 0;
 67     int xiao[5] = {2, 4, 6, 9, 11}; 
 68    if(d.month > 2){
 69        if(d.year % 4 == 0 && d.year % 100 != 0 || d.year % 400 == 0){
 70            i += 31 + 29;
 71        }
 72     else{
 73         i += 31 + 28;
 74     }
 75     for(j = d.month - 1; j > 2; j--){
 76         flag = 0;
 77         for(k = 0; k < 5; k++){
 78             if(j == xiao[k]){
 79                 flag = 1;
 80                 break;
 81             }
 82         }
 83         if(flag == 1){
 84             i += 30;
 85         }
 86         else{
 87             i += 31;
 88         }
 89     }
 90     i += d.day;
 91    }
 92    else if(d.month == 2){
 93       i = 31 + d.day;
 94    }
 95    else{
 96        i = d.day;
 97    } 
 98    return i;
 99 }
100 
101 // 补足函数compare_dates实现
102 // 功能:比较两个日期: 
103 // 如果d1在d2之前,返回-1;
104 // 如果d1在d2之后,返回1
105 // 如果d1和d2相同,返回0
106 int compare_dates(Date d1, Date d2) {
107     int ans;
108     if(d1.year == d2.year){
109         if(d1.month == d2.month){
110             if(d1.day == d2.day){
111                 ans = 0;
112             }
113             else if(d1.day > d2.day){
114                 ans = 1;
115             }
116             else{
117                 ans = -1;
118             }
119         }
120         else if(d1.month > d2.month){
121             ans = 1;
122         }
123         else{
124             ans = -1;
125         }
126     }
127     else if(d1.year > d2.year){
128         ans = 1;
129     }
130     else{
131         ans = -1;
132     }
133     return ans; 
134 }
View Code

运行结果截图

 实验任务6

程序源码

 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 
13 // 函数声明
14 void output(Account x[], int n);    // 输出账户数组x中n个账户信息,其中,密码用*替代显示
15 
16 int main() {
17     Account x[] = {{"A1001", "123456", student},
18                     {"A1002", "123abcdef", student},
19                     {"A1009", "xyz12121", student}, 
20                     {"X1009", "9213071x", admin},
21                     {"C11553", "129dfg32k", teacher},
22                     {"X3005", "921kfmg917", student}};
23     int n;
24     n = sizeof(x)/sizeof(Account);
25     output(x, n);
26 
27     return 0;
28 }
29 
30 // 待补足的函数output()实现
31 // 功能:遍历输出账户数组x中n个账户信息
32 //      显示时,密码字段以与原密码相同字段长度的*替代显示
33 void output(Account x[], int n) {
34     int i, j;
35     for(i = 0; i < n; i++){
36         for(j = 0; j < strlen(x[i].password); j++){
37             x[i].password[j] = '*';
38         }
39     }
40     for(i = 0; i < n; i++){
41         printf("%-20s%-20s", x[i].username, x[i].password);
42         switch (x[i].type){
43             case 0:
44                 printf("admin\n");
45                 break;
46             case 1:    
47                 printf("student\n");
48                  break;
49             case 2:
50                 printf("teacher\n");
51                 break;
52             default:
53                 break;         
54         }
55     } 
56      
57 }
View Code

运行结果截图

 

标签:int,编程,year,sales,枚举,实验,printf,d2,day
From: https://www.cnblogs.com/Eternity91/p/17894970.html

相关文章

  • 实验6 模板类、文件I/O和异常处理
    实验任务4Vector.hpp源代码1#include<iostream>2#include<stdexcept>34template<typenameT>5classVector{6private:7intsize;8T*vec;9public:10Vector<T>()=default;11......
  • 实验6
    //P286例8.17//对教材上的程序作了微调整,把输出学生信息单独编写成一个函数模块//打印不及格学生信息和所有学生信息程分别调用#include<stdio.h>#include<string.h>#defineN10//运行程序输入测试时,可以把这个数组改小一些输入测试typedefstructst......
  • calico网络实验
    一.部署1.手动安装calicocurlhttps://raw.githubusercontent.com/projectcalico/calico/v3.26.4/manifests/calico.yaml-Okubectlapply-fcalico.yaml 官网地址:https://docs.tigera.io/calico/latest/getting-started/kubernetes/quickstarthttps://docs.tigera.io/cal......
  • PKI实验
    实验概述实验目的  公钥加密是当今安全通信的基础,但是当通信的一方向另一方发送公钥时,却容易遭受到中间人攻击。根本问题在于没有一个简单的方式验证公钥所有者的身份。也就是说当收到一个公钥和它的所有者信息时,无法确定该公钥确实为这个所有者所拥有。公钥基础设施(PKI)就是解......
  • 实验六
    #include<stdio.h>#defineN10typedefstruct{charisbn[20];//isbn号charname[80];//书名charauthor[80];//作者doublesales_price;//售价intsales_count;//销售册数}Book;voidoutput(B......
  • 生活记录:和大师姐及实验室师兄弟一起吃鸡公煲留念——集积分兑换“毛绒玩具小猪”
    在实验室时每每出去聚餐吃饭总是喜欢去附近的鸡公煲,那家也是有个积分兑换毛绒玩具的活动,虽然最后也没有攒够积分而那家店在疫情中也没有熬过去,不过当年吃鸡公煲时是一直惦记着这个玩偶的,虽然未能实现自己的小目标但是这个经历还是蛮值得纪念的。   可爱的毛绒玩具——“小粉猪”......
  • CodeGeeX智能编程
    一、写在前面大家遇到代码不会的问题,本能的就会去求助chatGPT,但是没有梯子的话,chatGPT是不是也帮不上忙了?秉着白嫖的精神,分享给大家一款非常牛的插件CodeGeex。二、CodeGreex简介CodeGreex支持多种主流IDE,如VSCode、IntelliJIEAD、PyCharm、vim等,同时支持Python、java、C++/C......
  • 实验6 C语言结构体、枚举应用编程
    一、实验目的二、实验准备三、实验内容四、实验结果1.实验任务4源代码:1#include<stdio.h>2#defineN1034typedefstruct{5charisbn[20];//isbn号6charname[80];//书名7charauthor[80];//作者8......
  • SAP Spartacus BREAKPOINT 枚举类型在 Spartacus layout 实现中的作用
    BREAKPOINT在SAPSpartacusStorefront开源项目中是一个枚举类型,用于定义不同屏幕大小的断点。这个枚举类型默认包含五个屏幕名称:xs、sm、md、lg、xl,分别表示extrasmall、small、medium、large、extralarge的屏幕尺寸。这些尺寸通常与响应式设计中的断点概念相关联,用于确定......
  • 实验6
    task4.c1#include<stdio.h>2#defineN1034typedefstruct{5charisbn[20];//isbn号6charname[80];//书名7charauthor[80];//作者8doublesales_price;//售价9intsales_count;......