tags:

  • NOIP
  • 模拟
  • 倍增
  • 高精
  • Python

    categories:
  • 信息学竞赛
  • 总结

Luogu P1079 Vigenère 密码

Solution

  表示并不是很懂其他人发的题解.

  我是这么想的, 既然是题目要求用密文转明文而且转换规则一定的, 所以就可以用明文转密文的逆过程来完成.

  首先要搞明白明文是怎么变成密文的, 通过这个表可以观察到, 如果明文的一个字符是 ch1 ,密钥为 ch2 , 那么密文 ch3 对应的就是 ch1 在字母表中偏移 |ch2| 位, 例如  \(\text{ch1=A,ch2=B, ch3=ch1+|ch2|=A+B-A=B}\) , 如果偏移之后超过了 'Z', 那么就从'A'继续开始, 相当于这是一个环, 'Z'的后面是'A'.

  不难发现密文是明文在字母表中进行的偏移, 那么将密文转换为明文只需要将这个过程反过来就好了.只需要将密文减去一个密钥的偏移.例如 \(\text{ch3=F,ch2=C, ch1=ch3-|ch2|=F-(C-A)=D}\).

  知道了这个规则之后就不难写出程序了, 上面如果将其进行偏移出来比\(\text{A}\)小就利用取余来处理, 具体可以看代码

int cha=B-'A';
return 'A'+(A-cha-'A'+26)%26;

还需要注意几个问题:

  • 明文和密文对应的大小写是一致的.
  • 最好一开始把密文和明文都变成是大写, 这样好转化, 最后转化回来.
  • 第\(\text{ i }\)位密文对应的密钥为第\(\text{i}\mod \text{len2}\)位, 同样利用取余.
  • cctype库中几个函数, \(\text{islower(),tolower(),isupper(),islower()}\)比较好用, 参数为一个字符.

Code

#include<cctype>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define N 1005
using namespace std; char a[N],b[N];
int s,r,l; inline char Change(char A,char B){
int cha=B-'A';
return 'A'+(A-cha-'A'+26)%26;//将密文在字母表中进行一定偏移
} int main(){
scanf("%s%s",a,b);' r=strlen(a),l=strlen(b);
int flag=0;
for(int i=0;i<l;++i){ if(islower(b[i]))flag=1;
if(isupper(b[i]))flag=2;//记录一下密文一开始的大小写 if(islower(b[i]))b[i]=toupper(b[i]);//将密文和密钥都转化为大写
if(islower(a[i%r]))a[i%r]=toupper(a[i%r]); char ch=Change(b[i],a[i%r]);//得到明文的一个字符 if(flag==1)ch=tolower(ch);//再明文将其转化为密文一开始的大小写
if(flag==2)ch=toupper(ch); putchar(ch);//输出这个字符
}
return 0;
}

Luogu P1080 国王游戏

Solution

  首先题目我们需要对大臣进行一定的排序, 使得获得最多奖赏的大臣奖赏最少, 前面的题解已经写的很清楚了, 如果大臣 \(\text{a,b}\) , \(\text{a}\) 排在 \(\text{b}\) 前面的条件是 \(\text{a.left}\times \text{a.right}<\text{b.left}\times \text{b.right}\).

  那么做法就比较显然了, 只需要对所有人的左右手乘起来排个序就好.然后统计答案, 最头疼的地方是需要用高精, 我自然是非常头疼, 但是可以不用c++啊, 可以用 Python 水一波啊, 毕竟人家最擅长的就是科学运算.

  但是在用 Python 开心的写了一波之后发现只得了60分.竟然还 WA 了一个点, 真是没办法忍受, 然后想方设法得到了 RE 的数据, 发现了 RE 的原因.

OverflowError: integer division result too large for a float

  百度之后发现是因为Python的浮点数是c语言float, 所以会出锅.

然后就想自己写一个整数除法, 先取余, 然后二分除法的结果.结果又出现了类似的问题.醉了.

  然后又百度, 好像是找到三种解决方案

  • \(\text{from \_\_future\_\_ import division}\)
  • \(\text{divmod()}\)函数
  • \(\text{decimal}\)模块
  • \(\text{a//b}\), 等效于a整除b, 不会产生浮点运算, 但是不如第二种快, 不知道为什么.

  可以自己百度具体的使用方法.我使用的第二种方法, 实际上\(\text{divmod(a,b)}\)返回\(\text{(int(a/b), a mod b)}\)

  在通过上述艰难过程后, 终于通过了...

Code

#表示Python的注释
class Minister:#定义了一个类
def __init__(self, left, right, lefttimesright):#初始化函数
self.left = left
self.right = right
self.lefttimesright = lefttimesright
def __repr__(self):
return repr((self.left, self.right, self.lefttimesright)) n=int(input());#input()读入一行
wang=list(map(int,input().split()));#将读入的一行转化为[a,b,...], []为列表list
s=[] for i in range(0,n):
guo=list(map(int,input().split()));
s.append(Minister(guo[0],guo[1],guo[0]*guo[1])); ss=sorted(s, key=lambda student: student.lefttimesright)#将排序后的结果赋值给ss
lei=wang[0]
i=0
ans=0
while i<n:
jieguo=divmod(lei,ss[i].right)#jieguo=(a//b,a%b),jieguo[0]=a//b
#print(jieguo[0])
if jieguo[0]>ans:
ans=jieguo[0];
lei*=ss[i].left;
i=i+1; print(ans)#输出

开车旅行

Solution

NOIP 2012 Day1的更多相关文章

  1. 【NOIP 2012 开车旅行】***

    题目描述 小 A 和小 B 决定利用假期外出旅行,他们将想去的城市从 1 到 N 编号,且编号较小的 城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i 的海拔高度为 Hi,城市 ...

  2. NOIp 2012 #2 借教室 Label:区间修改线段树

    题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自然 ...

  3. NOIp 2012 #1 Vigenère 密码 Label:模拟

    题目描述 16 世纪法国外交家 Blaise de Vigenère 设计了一种多表密码加密算法――Vigenère 密 码.Vigenère 密码的加密解密算法简单易用,且破译难度比较高,曾在美国南 ...

  4. NOIP 2012 Day2T2 借教室题解

    NOIP 2012 Day2T2 借教室题解 题目传送门:http://codevs.cn/problem/1217/ 题目描述 Description 在大学期间,经常需要租借教室.大到院系举办活动 ...

  5. NOIP 2012 T5 借教室 [洛谷P1083]

    题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要 向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自 ...

  6. 【NOIP 2012 疫情控制】***

    题目描述 H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都, 也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控制疫情,不让疫情扩散 ...

  7. 【NOIP 2012 国王游戏】 贪心+高精度

    题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右 手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排 成一排,国王站在队伍 ...

  8. NOIP 2012 Vigenère 密码

    洛谷 P1079 Vigenère 密码 https://www.luogu.org/problemnew/show/P1079 JDOJ 1779: [NOIP2012]Vigenèr密码 D1 T ...

  9. P1080 【NOIP 2012】 国王游戏[贪心+高精度]

    题目来源:洛谷 题目描述 恰逢 H国国庆,国王邀请n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王 ...

随机推荐

  1. BZOJ2668:[CQOI2012]交换棋子——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=2668 https://www.luogu.org/problemnew/show/P3159#sub ...

  2. POJ1741 tree 【点分治】

    Tree Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 25286   Accepted: 8421 Description ...

  3. IE6“无法打开站点,已终止操作”提示的解决

    今天遇到一个问题,网站在IE 6下面打开会提示:Internet Explorer无法打开站点XXX.已终止操作. 先介绍一下网上常见的解决方法. 因为在页面还没有ready的时候就调用了htmlOb ...

  4. POJ 2763 Housewife Wind 纯粹LCA写法(简单无脑)

    Description After their royal wedding, Jiajia and Wind hid away in XX Village, to enjoy their ordina ...

  5. bzoj1177 [Apio2009]Oil 二维前缀最大值,和

    [Apio2009]Oil Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 2300  Solved: 932[Submit][Status][Disc ...

  6. 【设计模式】 模式PK:命令模式VS策略模式

    1.概述 命令模式和策略模式的类图确实很相似,只是命令模式多了一个接收者(Receiver)角色.它们虽然同为行为类模式,但是两者的区别还是很明显的.策略模式的意图是封装算法,它认为“算法”已经是一个 ...

  7. [Luogu 3224] HNOI2012 永无乡

    [Luogu 3224] HNOI2012 永无乡 特别水一个平衡树题. 不认真的代价是调试时间指数增长. 我写的 SBT,因为 Treap 的 rand() 实在写够了. 用并查集维护这些点的关系, ...

  8. PowerDesigner16 状态图

    状态图(Statechart Diagram)主要用于描述一个对象在其生存期间的动态行为,表现为一个对象所经历的状态序列,引起状态转移的事件(Event),以及因状态转移而伴随的动作(Action). ...

  9. 社会网络分析——Social Network Analysis

    什么是社会网络分析,英文social network analysis.现在这个分析越来越时髦,也越来越显现其在社会科学的研究价值.我在2000年的时候受祝建华老师的邀请到香港城市大学作研究,接触到 ...

  10. 阿里云maven仓库地址,速度提升100倍

    参照:https://www.cnblogs.com/xxt19970908/p/6685777.html maven仓库用过的人都知道,国内有多么的悲催.还好有比较好用的镜像可以使用,尽快记录下来. ...