您的位置:首页 > 编程语言 > Python开发

vijos - P1279Leave-绿光(数学归纳法 + python)

2015-08-16 09:37 423 查看
P1279Leave-绿光
Accepted

标签:[显示标签]


背景

期待这一份幸运,和一份冲劲,多么奇妙的际遇……。燕姿在演唱完绿光这首歌后,出给了姿迷一个考题。
北欧有一个传说!

人一生中能看见绿光!

他就一生都可以得到幸福!


描述

燕姿唱完这首歌,天上降落了一道绿光,在地上形成了一个矩形的映射,矩形的长为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).



#!/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)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: