P1279Leave-绿光

背景

期待这一份幸运,和一份冲劲,多么奇异的际遇……。

燕姿在演唱完绿光这首歌后,出给了姿迷一个考题。

北欧有一个传说!

人一生中能看见绿光!

他就一生都能够得到幸福。

描写叙述

燕姿唱完这首歌。天上降落了一道绿光。在地上形成了一个矩形的映射。矩形的长为a,宽为b。燕姿向姿迷出了一个考题。谁可以把这个矩形绿光阵分成若干个正整数的正方形。谁的正方形边长之和最小,他就将得到燕姿的一个合影。姿迷们都非常想得到合影,但是怎么分才最小呢?大家都束手无策,如今,这个问题交给你了。

歌迷X:呜呜呜,俺的语文不好,听不懂你在讲什么。

燕姿:别怕。事实上这个问题能够简化为……



将边长为正整数a,b的长方形划分成若干边长均为正整数,每一个正方形的边均平行于矩形的对应边,试求这些正方形边之和的最小值MIN。

(假设这个长方形能够分成N个正方形。当中每一个边长为Ai,那么MIN=A1+A2+^^^+AN

注意,数组A中的元素可能相等)

格式

输入格式

一共10行

每行两个正整数,Ai,Bi



对于30%的数据,Ai。Bi<maxint

对于100%的数据。Ai,Bi<maxlongint;

输出格式

一共10行

每行一个整数,输出MINi

例子1

例子输入1[复制]

1 1
2 1
3 1
4 1
5 1
6 1
7 1
8 1
9 1
10 1

例子输出1[复制]

1
2
3
4
5
6
7
8
9
10

限制

每点1s

提示

对于例子,可全分长边长为一的正方形,并

记所求最小值为f(m,n),能够证明f(m,n)=m+n-(m,n). (*)

当中(m,n)表示m和n的最大公约数.

其实,最好还是设m≥n.

(1)关于m归纳,能够证明存在一种合乎题意的分法,使所得正方形边长之和恰为m+n-(m,n).

当m=1时,命题显然成立. 

如果当m≤k时,结论成立(k≥1).当m=k+1时,若n= k+1,则命题显然成立.若n< k+1,从矩形ABCD中切去正方形一个边长为n(如图),

由归纳如果剩下的矩形有一种分法使得所得正方形边长之和恰为m-n+n-(m-n,n)= m-(m,n).

于是原矩形ABCD有一种分法使得所得正方形边长之和为m+n- (m,n).

(2)关于m归纳能够证明(*)成立.

当m=1时,因为n=1,显然f (m,n)=1= m+n- (m,n).

如果当m≤k时,对随意1≤n≤m有f (m,n)= m+n- (m,n).

若m=k+1,当n= k+1时,显然f(m,n)= k+1= m+n- (m,n).

当1≤n≤k时,设矩形ABCD按要求分成了p个正方形,其边长分别为a1,a2,…,ap,最好还是设a1≥a2≥…≥ap.

显然a1=n或a1若a1 m+n- (m,n).

若a1=n,则一个边长分别为m-n和n的矩形可按题目要求分成边长分别为a2,…,ap的正方形,由归纳如果

a2+…+ap≥m-n+n-(m-n,n)= m- (m,n).

从而a1+a2+…+ap≥m+n-(m,n).

于是当m=k+1时,f(m,n)≥m+n- (m,n).

再由(1)可知f (m,n)=m+n- (m,n).

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

#!/usr/bin/env python3
# -*- coding: utf-8 -*- def gcd(a, b):
if not b:
return a
else :
return gcd(b, a % b)
def lcm(a, b):
return a + b - gcd(a, b)
import sys
import math
for i in range(10):
a, b = map(int,raw_input().split())
print lcm(a, b)

vijos - P1279Leave-绿光(数学归纳法 + python)的更多相关文章

  1. Vijos——T1279 Leave-绿光

    https://vijos.org/p/1279 背景 期待这一份幸运,和一份冲劲,多么奇妙的际遇…….燕姿在演唱完绿光这首歌后,出给了姿迷一个考题. 北欧有一个传说!人一生中能看见绿光!他就一生都可 ...

  2. python 游戏(龙的国度)

    1. 理清楚游戏思路 实现功能:2个洞穴选择,一个洞穴是好龙,一个洞穴是坏龙,坏龙可以概率屠龙或者概率逃跑选项(后续难度需要增加宝藏获取装备,随机遇见商人,随着游戏进度逐步减少屠龙概率) 2. 计数和 ...

  3. 如何用 Python 给照片换色

    最近遇到了一个需求,就是对图片进行色彩风格转换,让一个物体可以以各种不同的色彩来呈现. 比如一个红色的苹果,我想把它转化成绿色,这可怎么办呢?本来想的解决方案是先识别边界,然后对边界内区域进行色彩替换 ...

  4. python全栈开发 * 08知识点汇总 * 180608

    08知识点梳理 文件操作一 .文件操作 r (只读)1.r (读) rb(字节)f=open("果蔬大杂烩",mode="r",encoding="U ...

  5. Python从菜鸟到高手(1):初识Python

    1 Python简介 1.1 什么是Python   Python是一种面向对象的解释型计算机程序设计语言,由荷兰人吉多·范罗苏姆(Guido van Rossum)于1989年发明,第一个公开发行版 ...

  6. 用C++画光(三)——色散

    写在前面 源码:https://github.com/bajdcc/GameFramework/blob/master/CCGameFramework/base/pe2d/Render2DScene5 ...

  7. RGB的光的三原色、品红黄青颜料的三原色

    学习了祁连山老师讲的光与色的基础知识,觉得收获颇多,所以记下来光与色的知识点. 首先提问大家一个问题:照片中物体的颜色就是它的固有色么?(请从色光和物体固有色的角度回答) 这个问题在看完下面的总结后相 ...

  8. 【系列】Python编程思想(1):Python简介与开发环境搭建

    李宁老师的 开始学习.   本系列文章深入介绍了Python的各种技术,堪称是目前最全的Python教程.主要目的是让读者可以了解Python的各种核心技术,包括各种Python函数库.本教程使用Py ...

  9. 一个人独立开发 3D 游戏引擎可能吗?

    作者:孙志超链接:https://www.zhihu.com/question/24733255/answer/42000966来源:知乎著作权归作者所有,转载请联系作者获得授权. 当然可以,但难道有 ...

随机推荐

  1. ACM_Ruin of Titanic(简单贪心)

    Ruin of Titanic Time Limit: 2000/1000ms (Java/Others) Problem Description: 看完Titanic后,小G做了一个梦.梦见当泰坦尼 ...

  2. 启用禁用USB接口

    一个小工具,功能有启用禁用外网.USB接口,可由服务端socket长链接进行操控客户端从而达到实现前边的这些功能,这里贴上核心代码,先给上启用禁用USB接口吧,这个方法可随时启用禁用,之前用过一个改u ...

  3. CF126B Password

    思路: kmp略作修改. 实现: #include <iostream> #include <cstdio> using namespace std; ; int neXt[M ...

  4. 通过yum命令搭建lamp环境(centos6.5)

    centos 6.5 1.yum安装和源代码编译在使用的时候没啥区别,但是安装的过程就大相径庭了,yum只需要3个命令就可以完成,源代码需要13个包,还得加压编译,步骤很麻烦,而且当做有时候会出错,源 ...

  5. (转)容易遗忘的JS知识点整理

    1.hasOwnProperty相关 为了判断一个对象是否包含自定义属性而不是原型链上的属性,我们需要使用继承自 Object.prototype 的 hasOwnProperty方法.hasOwnP ...

  6. 01--SQLite学习网站参考

    1.   SQLite基本操作 见我的02—SQLite一步到位 sqlite3编程笔记 . http://blog.csdn.net/wl_haanel/article/details/623141 ...

  7. JS——sort

    1.a-b升序 <script> var arr = [2, 3, 1, 5, 0]; function compare(a, b) { return a - b; } console.l ...

  8. linux最常用的快捷键

    1.ctrl+alt+T 调出命令行界面 2.alt+f4 关闭当前窗口

  9. SQL查询性能优化

    使用高效的查询 使用 EXISTS 代替 IN -- 查询A表中同时存在B表的数据 -- 慢 SELECT * FROM Class_A WHERE id IN (SELECT id FROM Cla ...

  10. 常见的CPU指令集介绍

    本文摘自网络   一.X86 是微处理器执行的计算机语言指令集,指一个intel通用计算机系列的标准编号缩写,也标识一套通用的计算机指令集合,属于CISC. 1.1.简介 X86指令集是美国Intel ...