202413350081刁嘉怡博客园2

news/2025/3/22 17:34:42/文章来源:https://www.cnblogs.com/diaojiayi/p/18782840

TASK1


 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <time.h>
 4 
 5 #define N 5
 6 
 7 int main() {
 8     int number;
 9     int i;
10 
11     srand(time(0));     // 以当前系统时间作为随机种子
12     for(i = 0; i < N; ++i) {
13         number = rand() % 100 + 1;
14         printf("20490042%04d\n", number);
15     }
16 
17     return 0;
18 }
task1

 

ANS1
随机生成1~100之间的整数
ANS2
指定4位宽度输出,不足用0填充
ANS3
随机抽取5个学号后3位在1~100的学生学号

 

TASK2

 1 #include <stdio.h>
 2 
 3 int main() {
 4     int choice, quantity;
 5     float total_price = 0, amount_paid, change;
 6 
 7     while (1) {
 8         printf("\n自动饮料售卖机菜单:\n");
 9         printf("1. 可乐 - 3 元/瓶\n");
10         printf("2. 雪碧 - 3 元/瓶\n");
11         printf("3. 橙汁 - 5 元/瓶\n");
12         printf("4. 矿泉水 - 2 元/瓶\n");
13         printf("0. 退出购买流程\n");
14         printf("请输入饮料编号: ");
15         scanf("%d", &choice);
16 
17         if (choice == 0)
18             break;
19 
20         if (choice < 1 || choice > 4) {
21             printf("无效的饮料编号,请重新输入。\n");
22             continue;
23         }
24 
25         printf("请输入购买的数量: ");
26         scanf("%d", &quantity);
27 
28         if (quantity < 0) {
29             printf("购买数量不能为负数,请重新输入。\n");
30             continue;
31         }
32 
33         switch (choice) {
34             case 1:
35             case 2:
36                 total_price += 3 * quantity;
37                 break;
38             case 3:
39                 total_price += 5 * quantity;
40                 break;
41             case 4:
42                 total_price += 2 * quantity;
43                 break;
44         }
45 
46         printf("请投入金额: ");
47         scanf("%f", &amount_paid);
48 
49         change = amount_paid - total_price;
50         printf("本次购买总价: %.2f 元\n", total_price);
51         printf("找零: %.2f 元\n", change);
52 
53         total_price = 0;
54     }
55 
56     printf("感谢您的购买,欢迎下次光临!\n");
57     return 0;
58 }
task2

ANS1
将上一次的总价清零。去掉之后下一次购买时的总价会加上之前的总价
ANS2
使用break会直接跳转到该框内的程序末尾,在这里也就是直接结束程序;continue使用后会继续重新运行框内程序,直到手动结束
ANS3
没有必要。前面的case语句已经完全涵盖取值并被明确处理

 

TASK3

 1 #include <stdio.h>
 2 
 3 int main() {
 4     char zifu;
 5     
 6     while(scanf("%c", &zifu)!= EOF){
 7         switch(zifu){
 8         case 'g':
 9             printf("GOGOGO\n");
10             break;
11         case 'y':
12             printf("wait a minute\n");
13             break;
14         case 'r':
15             printf("STOP\n");
16             break;
17         default:
18             printf("sth must be wrong...\n");
19             break;
20         }
21         while(getchar()!='\n');
22     }
23     
24    
25     return 0;
26 }
t3

 

TASK4

 

 1 #include <stdio.h>
 2 
 3 int main() {
 4     double exp;
 5     double total=0;
 6     double max=0;
 7     double min =20000;
 8     
 9     printf("输入今日开销,直到输入-1终止:\n");
10     while(1){
11             scanf("%lf",&exp);
12             if(exp==-1){
13             break;
14             }
15             total+=exp;
16             if(exp>max){
17                 max=exp;
18             }
19             if(exp<min){
20                 min=exp;
21             }
22             
23         }
24         printf("今日累计消费总额:%.1f\n",total);
25     
26         printf("今日最高一笔开销:%.1f\n",max);
27         
28         printf("今日最小一笔开销:%.1f\n",min);
29     
30    
31     return 0;
32 }
t4

 

 

TASK5

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <time.h>
 4 
 5 int main() {
 6    srand((unsigned int)time(NULL));
 7    int Lucky=rand()%30+1;
 8    int yh , chance = 3;
 9    printf("猜猜25年4月哪一天是你的lucky day\n");
10    while(chance > 0){
11            printf("开始咯,你有3次机会,猜吧(1~30):\n");
12            scanf("%d",&yh);
13            if (yh < Lucky){
14                printf("你猜的日期早了,你的lucky day还没到呢\n,再猜");
15                } 
16         if (yh > Lucky){
17             printf("你猜的日期晚了,你的lucky day在前面呢\n,再猜");
18             } 
19         if (yh == Lucky){
20             printf("猜中了!\n");
21             return 0;
22             } 
23         
24         chance--; 
25    }
26    
27    printf("次数用完了,告诉你,幸运日是&yh 号");
28     return 0;
29 }
t5

 

 

TASK6

 1 #include <stdio.h>
 2 #include<stdlib.h>
 3 int main()
 4 {
 5     int a,i,m,n;
 6     printf("input n: ");
 7     scanf("%d",&n);
 8 
 9     for(i=1;i<=n;++i){
10 
11         for(m = n - i + 1;m<n;++m)
12             printf("\t");
13 
14         for(a=0;a<2*(n-i)+1;++a)
15             printf(" O \t");
16         printf("\n");
17         
18         for(m=n-i+1;m<n;++m)
19             printf("\t");
20 
21         for(a=0;a<2*(n-i)+1;++a)
22             printf("<H>\t");
23         printf("\n");
24 
25         for(m=n-i+1;m<n;++m)
26             printf("\t");
27 
28         for(a=0;a<2*(n-i)+1;++a)
29             printf("I I\t");
30         printf("\n");
31     }
32     system("pause");
33     return 0;
34 }
t6

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/903545.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

四则运算结对项目

这个作业属于哪个课程 https://edu.cnblogs.com/campus/gdgy/SoftwareEngineeringClassof2023这个作业的目标 结对合作生成一个四则运算题目生成器结对成员 3123004365彭颂华 &&3123004354黄子恒github地址 https://github.com/PShua/zuoye &&https://github.c…

Vue3 vite 集成 sass

一、安装依赖npm install sass-embedded二、配置全局变量 1、新建文件 src/styles/variables.scss 2、配置Vite 修改 vite.config.jscss: {preprocessorOptions: {scss: {additionalData: `@use "@/styles/variables" as *;`,},},},3、测试使用 a、在variables.scss…

在Android studio 里面想要写入文本内容怎么做

在 AndroidManifest.xml 文件中添加写入外部存储的权限。如果是 Android 6.0(API 级别 23)及以上的系统,还需要在运行时请求权限。在 MainActivity 的 writeToFile 方法里调用 FileHelper 类: private void writeToFile(String content) { FileHelper.writeToInternalStora…

iptables 介绍与实战

iptables是Linux内核中用于配置防火墙规则的工具。它基于Netfilter框架,可以对通过网络接口的数据包进行过滤、修改等操作。通过设置一系列规则,iptables能够控制哪些数据包可以进入或离开系统,从而实现网络安全防护等功能。它主要工作在网络层,能够根据数据包的源地址、目…

CF771E题解

CF771E题解很容易设出 \(dp_{i,j}\) 表示第一行选到 \(i\),第二行选到 \(j\) 的方案数 首先考虑部分分。 \(|a_i|\le 1\),那么产生贡献的一个矩阵不会超过 \(2\),那么就没必要考虑 \(|i-j|\ge 4\) 的状态了。证明如下: 不妨设 \(i<j\),那么我与其从 \(dp_{i,j}\to dp_{…

Word目录链接中只选中开头的文字

Word目录链接中只选中开头的文字 Word目录想选第一个字却选中整行 word自动生成目录里选中第一个字不是选整段就是选一行,怎么解决解决方法: 【不行】按上档键Shift+Home键。 【不行】Windows有个很强大的Alt健,按住Alt之后,在目录里面就可以想选哪个选哪个,不会出现再你这…

基于MPPT控制的锂离子电池充电器

基于MPPT的集成电路,可跟踪电源点并对电池充电,最大额定功率为1A,外形尺寸为TP4056。当谈到独立的单电池充电器时,只有一个流行的名字进入我的脑海,那就是我们的多功能锂离子/锂po TP4056电池充电器。这是广泛使用的,有很多功能与电池保护有关。锂电池在市场上很容易获得…

【Linux文件】把/etc/passwd删除了,该怎么办?

场景: 在做渗透测试发现网站存在任意文件删除漏洞,测试删除了/etc/passwd,那么删除后该如何恢复?一、 /etc/passwd文件的作用 /etc/passwd 是 Linux 系统中存储用户账户信息的关键文件,包含用户名、UID、GID、主目录路径和默认 Shell 等。删除 /etc/passwd 仍会导致以下问题…

20244210 实验一《Python程序设计》实验报告

20244210 2024-2025-2 《Python程序设计》实验一报告 课程:《Python程序设计》 班级:2442 姓名: 陈可 学号:20244210 实验教师:王志强 实验日期:2024年3月18日 必修/选修: 公选课 1.实验内容 1.熟悉Python开发环境; 2.练习Python运行、调试技能; 3.编写程序,练习变…

Linux命令:top

Linux命令:top 简介 Linux top 是一个在 Linux 和其他类 Unix 系统上常用的实时系统监控工具。它提供了一个动态的、交互式的实时视图,显示系统的整体性能信息以及正在运行的进程的相关信息。 语法 top [-] [d delay] [q] [c] [S] [s] [i] [n] [b]参数说明:-d <秒数>:…

一次Java后端服务间歇性响应慢的问题排查记录

分享一个之前在公司内其它团队找到帮忙排查的一个后端服务连接超时问题,问题的表现是服务部署到线上后出现间歇性请求响应非常慢(大于10s),但是后端业务分析业务日志时却没有发现慢请求,另外由于服务容器`livenessProbe`也出现超时,导致容器出现间歇性重启。分享一个之前…

作业3:结对项目

这个作业属于哪个课程 软工23级这个作业要求在哪里 作业要求链接这个作业的目标 合作实现一个自动生成小学四则运算题目的命令行程序项目成员 陈日强 3123004736, 李铭恩 3123004745Github仓库链接 Math-Quiz-Generator一、PSP表格PSP2.1 阶段 任务 预估耗时(分钟) 实际耗时(…