天干地支&&承压计算

题目

古代中国使用天干地支来记录当前的年份。

将天干和地支连起来,就组成了一个天干地支的年份,例如:甲子。

2020 年是庚子年。每过一年,天干和地支都会移动到下一个。例如 2021 年是辛丑年。

思路

        找数学规律,用2020分别模10、12 得到的并不是庚子。我找的规律是2020%10 + 7、2020%12 + 9,看了题解发现其他规律也是可以的。 

代码

import os
import sys

# 请在此输入您的代码
tiangan = ['jia', 'yi', 'bing', 'ding', 'wu', 'ji', 'geng', 'xin', 'ren', 'gui']
dizhi = ['zi', 'chou', 'yin', 'mao', 'chen', 'si', 'wu', 'wei', 'shen', 'you', 'xu', 'hai']

year = int(input())

tian = (year+ 7) % 10 #得到天干的第几个
di = (year + 9) % 12
print(tiangan[tian - 1] + dizhi[di - 1]) #数组下标从0开始

题目

X 星球的高科技实验室中整齐地堆放着某批珍贵金属原料。

每块金属原料的外形、尺寸完全一致,但重量不同。 金属材料被严格地堆放成金字塔形。

其中的数字代表金属块的重量(计量单位较大)。 最下一层的 X 代表30 台极高精度的电子秤。

假设每块原料的重量都十分精确地平均落在下方的两个金属块上,最后,所有的金属块的重量都严格精确地平分落在最底层的电子秤上。

电子秤的计量单位很小,所以显示的数字很大。

工作人员发现,其中读数最小的电子秤的示数为:2086458231

请你推算出:读数最大的电子秤的示数为多少?

思路

还在那找规律呢,结果人家就直接遍历解出来了!呜呜呜 而且我一看见这种数据,我就害怕!一定要战胜这种恐惧!

代码

import os
import sys

# 请在此输入您的代码
data = '''                   7 
                            5 8 
                           7 8 8 
                          9 2 7 2 
                         8 1 4 9 1 
                        8 1 8 8 4 1 
                       7 9 6 1 4 5 4 
                      5 6 5 5 6 9 5 6 
                     5 5 4 7 9 3 5 5 1 
                    7 5 7 9 7 4 7 3 3 1 
                   4 6 4 5 5 8 8 3 2 4 3 
                  1 1 3 3 1 6 6 5 5 4 4 2 
                 9 9 9 2 1 9 1 9 2 9 5 7 9 
                4 3 3 7 7 9 3 6 1 3 8 8 3 7 
               3 6 8 1 5 3 9 5 8 3 8 1 8 3 3 
              8 3 2 3 3 5 5 8 5 4 2 8 6 7 6 9 
             8 1 8 1 8 4 6 2 2 1 7 9 4 2 3 3 4 
            2 8 4 2 2 9 9 2 8 3 4 9 6 3 9 4 6 9 
           7 9 7 4 9 7 6 6 2 8 9 4 1 8 1 7 2 1 6 
          9 2 8 6 4 2 7 9 5 4 1 2 5 1 7 3 9 8 3 3 
         5 2 1 6 7 9 3 2 8 9 5 5 6 6 6 2 1 8 7 9 9 
        6 7 1 8 8 7 5 3 6 5 4 7 3 4 6 7 8 1 3 2 7 4 
       2 2 6 3 5 3 4 9 2 4 5 7 6 6 3 2 7 2 4 8 5 5 4 
      7 4 4 5 8 3 3 8 1 8 6 3 2 1 6 2 6 4 6 3 8 2 9 6 
     1 2 4 1 3 3 5 3 4 9 6 3 8 6 5 9 1 5 3 2 6 8 8 5 3 
    2 2 7 9 3 3 2 8 6 9 8 4 4 9 5 8 2 6 3 4 8 4 9 3 8 8 
   7 7 7 9 7 5 2 7 9 2 5 1 9 2 6 5 3 9 3 5 7 3 5 4 2 8 9 
  7 7 6 6 8 7 5 5 8 2 4 7 7 4 7 2 6 9 2 1 8 2 9 8 5 7 3 6 
 5 9 4 5 5 7 5 5 6 3 5 3 9 5 8 9 5 4 1 2 6 1 4 3 5 3 2 4 1 
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 '''
d = data.replace(" ", "").split("\n")
for i in range(len(d)):  # 30 [0,30)
    d[i] = list(map(int, list(d[i])))  # 转换成int类型
for i in range(len(d) - 1):
    for j in range(i + 1):
        d[i + 1][j] += d[i][j] / 2
        d[i + 1][j + 1] += d[i][j] / 2
print(int(2086458231 / min(d[len(d) - 1]) * max(d[len(d) - 1])))
'''
题目中提出了,
金块的重量(计量单位大),电子秤的计量单位小。
好比,金块计量单位100,电子秤计量为5,
那么,我们通过正常计算可以得到最后金块总重量(但不知道计量单位),
但我们不确定金块重量跟电子秤之间的一个数值代换,
所以他提供了一个电子秤的准确数值,
让我们找到两者之间的数值比例,
最后求出ans.

比例:
最小示数 / 计算得出的最小重量 = 最大示数 / 计算得出的最大重量
故:
最大示数 = (最小示数 / 计算得出的最小重量) * 计算得出的最大重量
'''
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值