CCF CSP认证 历年题目自练 Day20

题目一

试题编号: 201903-1

试题名称: 小中大

时间限制: 1.0s

内存限制: 512.0MB

问题描述:

题目分析(个人理解)

  1. 常规题目,先看输入,第一行输入n表示有多少数字,第二行输入n个数,用空格分开。n=int(input())
    l=list(map(int,input().split()))
  2. 再看输出,最大值最小值都可以用函数max和min求出,问题是中位数如何计算,而且要保留一位小数。
  3. 那么对于中位数要讨论n的奇偶,由于输入时有要求不是降序就是升序排列,所以如果n是奇数,l[int(n/2)]就是中位数,如果n为偶数,就取(l[int(n / 2 - 1)] + l[int(n / 2)]) / 2就是中位数的数值,最后解决保留一位小数的问题,如果除的尽就是.0除不尽就保留一位。
  4. 上代码!!!
python 复制代码
n=int(input())
l=list(map(int,input().split()))
print(max(l),end='')
if n%2==1:
    print('',l[int(n/2)],end='')
else:
    pr = (l[int(n / 2 - 1)] + l[int(n / 2)]) / 2
    if pr%1==0.0:
        print('','%.0f' %pr,end='')
    else:
        print('','%.1f' %pr,end='')
print('',min(l))

题目二

试题编号: 201903-2

试题名称: 二十四点

时间限制: 1.0s

内存限制: 512.0MB

题目分析(个人理解)

  1. 题目巴拉巴拉说了半天就是确定一下运算完了是不是24,是就YES不是就No,关键的是将特殊符号换成运算符,我使用replace方法就可实现,非常简单。
  2. 然后判断之后输出即可。
  3. 上代码!!!
python 复制代码
n = int(input())
for i in range(n):
    s=input()
    s = s.replace("/", "//")  # //换成整除
    s = s.replace("x", "*")  # x换成乘法
    sum = eval(s)  # 执行表达式得出运算结果
    if (sum == 24):
        print("Yes")
    else:
        print("No")
  1. 简化版:
python 复制代码
for i in range(int(input())): 
	print('Yes' if eval(input().replace('x', '*').replace('/', '//')) == 24 else 'No')

总结

今天终于能按时干饭了,主要是今天的两题过于简单。

我的炸酱面Pro Max版:

相关推荐
AndrewHZ2 分钟前
【图像处理基石】有哪些好用的图像去噪算法可以推荐一下么?
图像处理·深度学习·算法·计算机视觉·cv·噪声
我命由我123455 分钟前
Photoshop - Photoshop 工具栏(47)油漆桶工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
雪花desu7 分钟前
【Hot100-Java中等】:字母异位词分组
java·算法·leetcode·哈希表
Word码8 分钟前
LeetCode283. 移动零(双指针精讲)
算法·leetcode·职场和发展
胡伯来了10 分钟前
08 - 数据收集 - 网页采集工具Selenium
爬虫·python·selenium·rag·网络采集
xiaoxue..10 分钟前
二叉搜索树 BST 三板斧:查、插、删的底层逻辑
javascript·数据结构·算法·面试
蒙奇D索大11 分钟前
【数据结构】排序算法精讲 | 快速排序全解:分治思想、核心步骤与示例演示
数据结构·笔记·学习·考研·算法·排序算法·改行学it
沃斯堡&蓝鸟12 分钟前
DAY31 函数专题2:装饰器
python
ss27312 分钟前
Executors预定义线程池-正确使用姿势
linux·开发语言·python
七夜zippoe12 分钟前
Python高级数据结构深度解析:从collections模块到内存优化实战
开发语言·数据结构·python·collections·内存视图