(poj1.3.2)1791(构造法模拟)

/*
 * 1791_1.cpp
 *
 *  Created on: 2013年10月6日
 *      Author: Administrator
 */

#include <iostream>
#include <cstdio>

using namespace std;

const int TOO_BIG = INT_MAX;

int ncuts(int a,int b,int c,int d,int e,int f){
	if(a*c > e || b*d > f){
		return TOO_BIG;
	}

	return a*b - 1 + (a*c < e) +(b*d < f);

}

void do_solve(int a , int b , int c,int d, int e, int f){
	int m = ncuts(a,b,c,d,e,f);
    int x = 0;
	if( (x = ncuts(b,a,c,d,e,f)) < m){
		m = x;
	}

	if( (x = ncuts(a,b,d,c,e,f)) < m){
		m = x;
	}

	if((x = ncuts(b,a,d,c,e,f)) < m ){
		m = x;
	}

	if(m == TOO_BIG){
		printf("The paper is too small.\n");
	}else{
		printf("The minimum number of cuts is %d.\n",m);
	}
}



int main(){
	int a,b,c,d,e,f;
	while(scanf("%d%d%d%d%d%d",&a,&b,&c,&d,&e,&f) != EOF ,a&&b&&c&&d&&e&&f){
		do_solve(a,b,c,d,e,f);
	}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值