【PTA 题解】L1-083 谁能进图书馆(标志位)(C+Python)

题目

为了保障安静的阅读环境,有些公共图书馆对儿童入馆做出了限制。例如“12 岁以下儿童禁止入馆,除非有 18 岁以上(包括 18 岁)的成人陪同”。现在有两位小/大朋友跑来问你,他们能不能进去?请你写个程序自动给他们一个回复。

输入格式:

输入在一行中给出 4 个整数:
禁入年龄线 陪同年龄线 询问者1的年龄 询问者2的年龄
这里的禁入年龄线是指严格小于该年龄的儿童禁止入馆;陪同年龄线是指大于等于该年龄的人士可以陪同儿童入馆。默认两个询问者的编号依次分别为 12;年龄和年龄线都是 [1, 200] 区间内的整数,并且保证 陪同年龄线 严格大于 禁入年龄线

输出格式:

在一行中输出对两位询问者的回答,如果可以进就输出 年龄-Y,否则输出 年龄-N,中间空 1 格,行首尾不得有多余空格。

在第二行根据两个询问者的情况输出一句话:

  • 如果两个人必须一起进,则输出 qing X zhao gu hao Y,其中 X 是陪同人的编号, Y 是小孩子的编号;
  • 如果两个人都可以进但不是必须一起的,则输出 huan ying ru guan
  • 如果两个人都进不去,则输出 zhang da zai lai ba
  • 如果一个人能进一个不能,则输出 X: huan ying ru guan,其中 X 是可以入馆的那个人的编号。

输入样例 1:

12 18 18 8

输出样例 1:

18-Y 8-Y
qing 1 zhao gu hao 2

输入样例 2:

12 18 10 15

输出样例 2:

10-N 15-Y
2: huan ying ru guan

解析

可以列表分析,假设 A 0 B 0 表示 A 为状态 0,B 为状态 0。
状态 0:< 禁入年龄线
状态 1:禁入年龄线 ~ 陪同年龄线
状态 2:>= 陪同年龄线

用 Excel 列成表格,然后翻译成对应的代码即可
excel 表格

代码

Python 版本

min_entry_age, min_parent_age, age1, age2 = [int(x) for x in input().split(' ')]

if age1 < min_entry_age:
    state1 = 0
elif age1 < min_parent_age:
    state1 = 1
elif age1 >= min_parent_age:
    state1 = 2
if age2 < min_entry_age:
    state2 = 0
elif age2 < min_parent_age:
    state2 = 1
elif age2 >= min_parent_age:
    state2 = 2
    
match (state1, state2):
	case (0, 0):
		print(f'{age1}-N {age2}-N')
		print('zhang da zai lai ba')
	case (0, 1):
		print(f'{age1}-N {age2}-Y')
		print('2: huan ying ru guan')
	case (0, 2):
		print(f'{age1}-Y {age2}-Y')
		print('qing 2 zhao gu hao 1')
	case (1, 0):
		print(f'{age1}-Y {age2}-N')
		print('1: huan ying ru guan')
	case (1, 1):
		print(f'{age1}-Y {age2}-Y')
		print('huan ying ru guan')
	case (1, 2):
		print(f'{age1}-Y {age2}-Y')
		print('huan ying ru guan')
	case (2, 0):
		print(f'{age1}-Y {age2}-Y')
		print('qing 1 zhao gu hao 2')
	case (2, 1):
		print(f'{age1}-Y {age2}-Y')
		print('huan ying ru guan')
	case (2, 2):
		print(f'{age1}-Y {age2}-Y')
		print('huan ying ru guan')

C 版本

#include <stdio.h>

int main() {
    int min_entry_age, min_parent_age, age1, age2;
    scanf("%d %d %d %d", &min_entry_age, &min_parent_age, &age1, &age2);

    int state1, state2;
    if (age1 < min_entry_age)
        state1 = 0;
    else if (age1 < min_parent_age)
        state1 = 1;
    else if (age1 >= min_parent_age)
        state1 = 2;

    if (age2 < min_entry_age)
        state2 = 0;
    else if (age2 < min_parent_age)
        state2 = 1;
    else if (age2 >= min_parent_age)
        state2 = 2;

    if (state1 == 0 && state2 == 0) {
        printf("%d-N %d-N\n", age1, age2);
        printf("zhang da zai lai ba\n");
    } else if (state1 == 0 && state2 == 1) {
        printf("%d-N %d-Y\n", age1, age2);
        printf("2: huan ying ru guan\n");
    } else if (state1 == 0 && state2 == 2) {
        printf("%d-Y %d-Y\n", age1, age2);
        printf("qing 2 zhao gu hao 1\n");
    } else if (state1 == 1 && state2 == 0) {
        printf("%d-Y %d-N\n", age1, age2);
        printf("1: huan ying ru guan\n");
    } else if (state1 == 1 && state2 == 1) {
        printf("%d-Y %d-Y\n", age1, age2);
        printf("huan ying ru guan\n");
    } else if (state1 == 1 && state2 == 2) {
        printf("%d-Y %d-Y\n", age1, age2);
        printf("huan ying ru guan\n");
    } else if (state1 == 2 && state2 == 0) {
        printf("%d-Y %d-Y\n", age1, age2);
        printf("qing 1 zhao gu hao 2\n");
    } else if (state1 == 2 && state2 == 1) {
        printf("%d-Y %d-Y\n", age1, age2);
        printf("huan ying ru guan\n");
    } else if (state1 == 2 && state2 == 2) {
        printf("%d-Y %d-Y\n", age1, age2);
        printf("huan ying ru guan\n");
    }

    return 0;
}

补充

C 语言的 switch 由于没法像 Python match 那样可以一下匹配两个数,只能写一大堆啰嗦的 if elseif。
可以考虑合并两个 state 为一个数,然后再用 switch 语句来判断。

怎么合并呢?
我们的 state 可以取 0、1、2,对应二进制 00、01、10,只需要用两个 bit 就可表示。两个 state 总共就是 4 bit,而 C 语言里最小的整数 char 也有 8 bit,完全放得下。

所以做法是,用一个 char 类型变量,总共 8 bit,从低往高(从右往左)第 1、2 位是 state1,第 3、4 位是 state2,剩下的不用,保持为 0。

比如 state1=0,state2=2,那么 state=

00 00 10(state2) 00(state1)

也就是 8。

这是修改后的代码,相同的部分就不重复写了

char state = 0b0000;
if (age1 < min_entry_age)
    state |= 0b0001; // 1
else if (age1 < min_parent_age)
    state |= 0b0010; // 2
else
    state |= 0b0011; // 3

if (age2 < min_entry_age)
    state |= 0b0100;
else if (age2 < min_parent_age)
    state |= 0b1000;
else
    state |= 0b1100;

// switch 部分
switch (state) {
    case 0b0000:
        printf("%d-N %d-N\n", age1, age2);
        printf("zhang da zai lai ba\n");
        break;
    case 0b0001:
    	//剩下的按照上面的方法算出来就可以了
    	//...
    	
}

这种利用位来标记信息的方式很常见,比如标志变量 int flag,不同位的含义各不相同,为 1 表示启用,为 0 表示禁用。
这么做的好处是可以把很多参数/变量合并为一个。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

穿戴规范智能识别系统 yolov7

穿戴规范智能识别系统通过yolov7python网络模型AI深度视觉学习算法&#xff0c;穿戴规范智能识别系统对工厂画面中人员穿戴行为自动识别分析&#xff0c;发现现场人员未按照规定穿戴着装&#xff0c;立即抓拍告警。YOLOv7 的发展方向与当前主流的实时目标检测器不同&#xff0c…

代码版本M、RC、GA、Release等标识的区别

引言 最近听说spring framework有了重大版本调整&#xff0c;出了6.0的GA版本了 那GA是啥意思呢&#xff1f; 看了下spring 官网和代码仓库&#xff0c;除了GA&#xff0c;还有M、RC、Release等 Spring FrameworkLevel up your Java code and explore what Spring can do f…

PCL源码剖析 -- 欧式聚类

PCL源码剖析 – 欧式聚类 参考&#xff1a; 1. pcl Euclidean Cluster Extraction教程 2. 欧式聚类分析 3. pcl-api源码 4. 点云欧式聚类 5. 本文完整工程地址 可视化结果 一. 理论 聚类方法需要将无组织的点云模型P划分为更小的部分&#xff0c;以便显著减少P的总体处理时间…

【hello Linux】Linux下 gitee 的使用

目录 1. 安装 git 2. gitee 的使用 2.1 注册 gitee 账号 2.2 创建项目&#xff1a;也就是仓库 2.3 下载项目到本地 3. 上传gitee三步走 3.1 三板斧第一招&#xff1a;git add 3.2 三板斧第二招&#xff1a;git commit 3.3 三板斧第三招&#xff1a;git push Linux&#x1f337…

海外虚拟主机空间:如何使用CDN加速提升用户体验?

随着互联网的迅速发展和全球化的趋势&#xff0c;越来越多的企业和个人选择海外虚拟主机空间。然而&#xff0c;由于服务器的地理位置和网络延迟等原因&#xff0c;这些网站在国内访问时可能会遇到较慢的加载速度和不稳定的用户体验。为了解决这一问题&#xff0c;使用CDN加速是…

【Linux】进程理解与学习Ⅳ-进程地址空间

环境&#xff1a;centos7.6&#xff0c;腾讯云服务器Linux文章都放在了专栏&#xff1a;【Linux】欢迎支持订阅&#x1f339;相关文章推荐&#xff1a;【Linux】冯.诺依曼体系结构与操作系统【Linux】进程理解与学习Ⅰ-进程概念浅谈Linux下的shell--BASH【Linux】进程理解与学习…

[JavaEE]----Spring01

文章目录Spring_day011&#xff0c;课程介绍1.1 为什么要学?1.2 学什么?1.3 怎么学?2&#xff0c;Spring相关概念2.1 初识Spring2.1.1 Spring家族2.1.2 了解Spring发展史2.2 Spring系统架构2.2.1 系统架构图2.2.2 课程学习路线2.3 Spring核心概念2.3.1 目前项目中的问题2.3.…

VN5620以太网测试——环境搭建篇

文章目录 前言一、新建以太网工程二、Port Configuration三、Link up四 Trace界面五、添加Ethernet Packet Builder六、添加ARP Packet七、添加Ethernet IG总结前言 CANoe(CAN open environment)VN5620 :是一个紧凑而强大的接口,用于以太网网络的分析、仿真、测试和验证。 …

面试篇-深入理解 Java 中的 HashMap 实现原理

一、HashMap实现原理 HashMap 的实现主要包括两个部分&#xff1a;哈希函数和解决哈希冲突的方法。 1.哈希函数 当使用 put() 方法将键值对存储在 HashMap 中时&#xff0c;首先需要计算键的哈希值。HashMap 使用 hashCode() 方法获取键的哈希值&#xff0c;并将其转换为桶&…

2023-04-11 无向图的匹配问题

无向图的匹配问题 之所以把无向图的这个匹配问题放到最后讲是因为匹配问题借鉴了有向图中一些算法的思想 1 最大匹配和完美匹配 二分图回顾 二分图&#xff1a;把一个图中的所有顶点分成两部分&#xff0c;如果每条边的两端分别属于不同部分&#xff0c;则这个图是二分图。更多…

springcloud——gateway功能拓展

目录 1.获取用户真实IP 2.统一跨域配置 3.redis令牌桶算法限流 1.获取用户真实IP 在我们的日常业务中&#xff0c;我们时常需要获取用户的IP地址&#xff0c;作登录日志、访问限制等相关操作。 而在我们的开发架构中&#xff0c;一般我们将服务分为多个微服务&#xff0c;…

Python 进阶指南(编程轻松进阶):一、处理错误和寻求帮助

原文&#xff1a;http://inventwithpython.com/beyond/chapter1.html 请您不要将计算机当成佣人&#xff0c;因为这样会让您常常感觉很烦躁。比如说当计算机向您显示错误消息时&#xff0c;并不是因为您冒犯了它。计算机是我们大多数人都会接触到的最复杂的工具&#xff0c;但归…

HBase高手之路4-Shell操作

文章目录HBase高手之路3—HBase的shell操作一、hbase的shell命令汇总二、需求三、表的操作1&#xff0e;进入shell命令行2&#xff0e;创建表3&#xff0e;查看表的定义4&#xff0e;列出所有的表5&#xff0e;删除表1)禁用表2)启用表3)删除表四、数据的操作1&#xff0e;添加数…

【HAL库】BMP180气压传感器+STM32,hal库移植

BMP180气压传感器STM321 导入.c.h文件&#xff08;不再赘述&#xff0c;详细见LED部分&#xff09;2 Cubemx配置3 修改 .h 文件4 测试将BMP180从标准库移植到HAL库。模拟IIC。 极简工程代码如下&#xff1a; https://github.com/wyfroom/HAL_BMP180 该份代码硬件配置&#xff…

Oracle_EBS_核心功能(MFG)(1)

INV: Items参考《深入浅出Oracle EBS之核心功能&#xff08;DIS&#xff09;》。canca INV: Transactions基本库存事务处理参考《深入浅出Oracle EBS之核心功能&#xff08;DIS&#xff09;》。canca BOM: Bills of Material物料清单应用&#xff1a;Bills of Material 职责&am…

day-004-链表-两两交换链表中的节点、删除链表的倒数第N个节点、链表相交、环形链表II

两两交换链表中的节点 题目建议&#xff1a;用虚拟头结点&#xff0c;这样会方便很多。 题目链接/文章讲解/视频讲解 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* Li…

阿里9年测试经验告诉你:作为一名年薪40w自动化测试需要具备那些能力

前言 前段时间张同学问我说&#xff1a;我已经功能测试2年多了&#xff0c;在功能测试的阶段中也一直在自学自动化测试&#xff0c;有了一定的代码基础还学习了很多的工具&#xff0c;问题是我不知道自动化测试到底需要具备什么样的能力。 我相信有很多小伙伴也是在思索这个问…

计算机组成的基本认识

计算机——> 数值计算——> 处理电信号——> 基本单元&#xff08;逻辑元件&#xff09; 电子管——> 晶体管——>中小规模集成电路 ——>大规模&#xff0c;超大规模集成电路 机器字长&#xff1a;计算机一次整数运算所能处理的二进制位数 解析存储器中的程…

这家年销售额309亿的Tier 1,要谈一场千亿新生意

跨入2023年&#xff0c;智能汽车软件赛道更热闹了。 相较于传统汽车开发模式&#xff0c;软件属于分布式ECU工程开发的一部分&#xff0c;由一级供应商作为黑盒提供&#xff0c;软件开发成本等被认为是硬件系统成本的一部分&#xff0c;没有实现单独定价。 如今&#xff0c;“…

如何在windows/linux下启动OpenOffice

上面一篇文章使用openOffice来实现预览word、excel、pdf、txt等的功能时&#xff0c;发现openOffice没有启动&#xff0c;也怕有些同学安装后不会启动&#xff0c;所以便写下这一篇文章&#xff0c;来为大家说明如何启动openOffice&#xff0c;上一篇讲的如何下载安装openOffic…