首页 > 其他分享 >实验六

实验六

时间:2024-06-08 23:23:11浏览次数:20  
标签:int 31 30 day 实验 printf void

task4

 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 void output(Book x[], int n){
39     int i;
40     printf("ISBN号              书名                        作者                   售价  销售册数\n");
41     for(i=0;i<n;i++)
42         printf("%s   %-25s   %-20s   %-4.1lf     %-4d\n",x[i].isbn,x[i].name,x[i].author,x[i].sales_price,x[i].sales_count); 
43 }
44 
45 
46 // 待补足:函数sort()实现
47 void sort(Book x[], int n){
48     int i,j;
49     Book t;
50     
51     for(i=0;i<n-1;i++)
52         for(j=0;j<n-1-i;j++)
53            if(x[j].sales_count<x[j+1].sales_count){
54                  t=x[j];
55                  x[j]=x[j+1];
56                  x[j+1]=t;
57            }
58 }
59 
60 
61 // 待补足:函数sales_count()实现
62 double sales_amount(Book x[], int n){
63     int i;double s=0;
64     
65     for(i=0;i<n;i++)
66         s=s+x[i].sales_price*x[i].sales_count;
67         
68     return s;
69 }

 

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();   // 测试函数1: 测试某个日期时这一年第多少天                   
 18 void test2();   // 测试函数2: 测试两个日期先后顺序
 19 
 20 
 21 int main() {
 22     printf("测试1: 输入日期, 打印输出这是一年中第多少天\n");
 23     test1();
 24 
 25     printf("\n测试2: 两个人年龄大小关系\n");
 26     test2();
 27 }
 28 
 29 // 测试函数实现
 30 void test1() {
 31     Date d;
 32     int i;
 33 
 34     printf("输入日期:(以形如2024-06-01这样的形式输入)\n");
 35     for(i = 0; i < 3; ++i) {
 36         input(&d);
 37         printf("%04d-%02d-%02d是这一年中第%d天\n\n", d.year, d.month, d.day, day_of_year(d));
 38     }
 39 }
 40 
 41 void test2() {
 42     Date Alice_birth, Bob_birth;
 43     int i;
 44     int ans;
 45 
 46     printf("输入Alice和Bob出生日期:(以形如2005-08-11这样的形式输入)\n");
 47     for(i = 0; i < 3; ++i) {
 48         input(&Alice_birth);
 49         input(&Bob_birth);
 50         ans = compare_dates(Alice_birth, Bob_birth);
 51         
 52         if(ans == 0)
 53             printf("Alice和Bob一样大\n\n");
 54         else if(ans == -1)
 55             printf("Alice比Bob大\n\n");
 56         else
 57             printf("Alice比Bob小\n\n");
 58     }
 59 }
 60 
 61 // 补足函数input实现
 62 // 功能: 输入日期给pd指向的Date变量
 63 void input(Date *pd) {
 64     scanf("%d-%d-%d",&(pd->year),&(pd->month),&(pd->day));
 65 }
 66 
 67 // 补足函数day_of_year实现
 68 // 功能:返回日期d是这一年的第多少天
 69 int day_of_year(Date d) {
 70     int i,sum=0;
 71     int year1[12]={31,28,31,30,31,30,31,31,30,31,30,31};
 72     int year2[12]={31,29,31,30,31,30,31,31,30,31,30,31};
 73     
 74     if((d.year%4==0&&d.year%100!=0)||(d.year%400==0)){
 75         for(i=1;i<d.month;i++)
 76            sum=sum+year2[i];
 77     }
 78     else{
 79         for(i=1;i<d.month;i++)
 80            sum=sum+year1[i];
 81     }
 82     sum=sum+d.day;
 83     return sum;
 84 }
 85 
 86 // 补足函数compare_dates实现
 87 // 功能:比较两个日期: 
 88 // 如果d1在d2之前,返回-1;
 89 // 如果d1在d2之后,返回1
 90 // 如果d1和d2相同,返回0
 91 int compare_dates(Date d1, Date d2) {
 92     if(d1.year < d2.year ){
 93         return -1;
 94     }
 95     if(d1.year > d2.year ){
 96         return 1;
 97     }
 98     if(d1.year ==d2.year ){
 99         if(d1.month  < d2.month  ){
100             return -1;
101         }
102         else if(d1.month  > d2.month  ){
103             return 1;
104         }
105         else{
106             if(d1.day  < d2.day  ){
107                 return -1;
108             }
109             else if(d1.day  > d2.day   ){
110                 return 1;
111             }
112             else
113                 return 0;
114         }
115     }
116 }

 

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 
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     int k;
36     for(i=0;i<n;i++){
37         printf("%-20s",x[i].username);
38         k=strlen(x[i].password);
39         for(j=0;j<k;j++){
40             printf("*");
41         }
42         printf("\t               ");
43         switch(x[i].type){
44             case admin:printf("admin\n");break;
45             case student:printf("student\n");break;
46             case teacher:printf("teacher\n");break;
47         }
48     } 
49 
50 }

 

标签:int,31,30,day,实验,printf,void
From: https://www.cnblogs.com/wxy0105/p/18239087

相关文章

  • DOM型xss靶场实验
    DOM型xss可以使用js去控制标签中的内容。我使用的是一个在线的dom型xss平台,靶场链接:Challenges第一关MaSpaghet!:MaSpaghet!关卡<h2id="spaghet"></h2><script>spaghet.innerHTML=(newURL(location).searchParams.get('somebody')||"Somebody&qu......
  • C语言实验六
    #include<stdio.h>#include<string.h>#defineN3//运行程序输入测试时,可以把这个数组改小一些输入测试typedefstructstudent{intid;//学号charname[20];//姓名charsubject[20];//考试科目doublepe......
  • kvm链接克隆虚拟机迁移到openstack机器的实验
     总结如果是完整克隆的那种虚拟机,是可以直接在openstack使用的,如果镜像格式没问题的话。 因为kvm虚拟机大部分都是链接克隆出来的镜像,不可用直接复制使用,所以需要创建新的镜像文件 创建空盘:qemu-imgcreate-fqcow2mcwlink1-new.qcow250G将链接克隆镜像数据导入到空......
  • 实验6
    `#include<stdio.h>include<stdlib.h>include<string.h>defineN3 //运行程序输入测试时,可以把这个数组改小一些输入测试typedefstructstudent{intid; //学号charname[20]; //姓名charsubject[20]; //考试科目doubleperf; //平时成绩doublemid;......
  • 设备树下的 LED 驱动实验
    设备树下的LED驱动实验本章实验重点内容如下:①、在imx6ull-alientek-emmc.dts文件中创建相应的设备节点。②、编写驱动程序(在第四十二章实验基础上完成),获取设备树中的相关属性值。③、使用获取到的有关属性值来初始化LED所使用的GPIO。设备树文件添加设备节点:在根......
  • Java 实验8 集合类
    (一)实验目的1、掌握JAVA集合类中的Collection的特点及其应用情形;3、掌握Collection、熟悉集合的特点及应用。(二)实验内容和步骤1、仿照课堂练习的MyStack示例,使用LinkedList集合类实现一个先进先出的队列数据结构,可以往该结构中压入数据push()以及弹出数据pop(),并遵循先进入......
  • 实验 6
    task1点击查看代码#include<stdio.h>#include<string.h>#defineN3 //运行程序输入测试时,可以把这个数组改小一些输入测试typedefstructstudent{ intid; //学号 charname[20]; //姓名 charsubject[20]; //考试科目 doubleperf; //平时成......
  • 【GD32F303红枫派使用手册】第十节 FWDGT-独立看门狗实验
    10.1实验内容通过本实验主要学习以下内容:独立看门狗的原理独立看门狗功能介绍实现独立看门狗功能10.2实验原理10.2.1看门狗的原理一般来说,搭配MCU的产品都需要有长期运行的需求,特别像一些工业设备,可能要求运行个几年都不关机,但谁也不能保证在这几年里,MCU里面的代码......
  • 【GD32H757Z海棠派使用手册】第十三讲 USB-虚拟键盘实验
    13.1实验内容通过本实验主要学习以下内容:USB协议基本原理GD32H7xxUSBHS的使用虚拟键盘的协议原理及使用13.2实验原理13.2.1USB通信基础知识USB的全称是UniversalSerialBus,通用串行总线。它的出现主要是为了简化个人计算机与外围设备的连接,增加易用性。USB支持热......
  • 计算机网络实验二:动态路由配置
    这个是pkt文件https://pan.quark.cn/s/5a80aa8a21f7发现复制不来图片把实验报告也放在夸克网盘大家自行下载https://pan.quark.cn/s/1d9ea9d31bea有兴趣的可以一点一点跟着做没兴趣的自行下载提交(手动狗头)实验报告里面有私货记得删除修改这个pkt文件我没有配置协......