码迷,mamicode.com
首页 > 其他好文 > 详细

U4699 鸡蛋

时间:2016-09-18 22:10:02      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:

 U4699 鸡蛋

    • 0通过
    • 37提交
  • 题目提供者飞翔
  • 标签
  • 难度尚无评定

  

最新讨论

  • 暂时没有讨论

题目背景

调皮的kkk准备恶搞他的同学兼朋友——你!

题目描述

kkk准备从楼上扔鸡蛋下来砸在lzn身上,让lzn变成“鸡蛋王子”。但是如果鸡蛋没有破裂,辣么就没有什么好玩的了,所以kkk必须知道鸡蛋最少在哪一层楼上扔下来会摔破。

kkk为了实验事先买了K个鸡蛋(这些鸡蛋的硬度一样),并来到了一个N层高楼上。每次kkk可以拿着一个鸡蛋从t楼扔下去,并观察鸡蛋有没有摔破。如果鸡蛋在第t层楼没有摔破,那么在1..t-1层楼都不会摔破,而且不论在1..t层楼摔多少次鸡蛋都不会破。

lzn马上就要过来了,所以你需要帮kkk求出,她最少要做多少次实验。

输入输出格式

输入格式:

 

有多组数据,每组数据包含两个整数K和N

 

输出格式:

 

对于每组数据输出最少实验次数,如果实验63次还不能成功,输出TLE

 

输入输出样例

输入样例#1:
2 100
1 100
输出样例#1:
14
TLE

说明

1<=K<=100

1<=N<2^64

题解:

数据范围太大,二分就拜拜了。

只能用考虑dp or递推。

然后自己软腿就推出来了。

f[i][j]表示i个鸡蛋扔j次恰好是f[i][j]层随

转移f[i][j]=f[i][j-1]+f[i-1][j-1]+1;

AC代码:

#include<iostream>
#include<cstdio>
using namespace std;
long long f[105][3001];
long long k,n;
int main(){
    for(int a=1;a<=101;a++)
        for(int b=1;b<=3000;b++)
            f[a][b]=f[a][b-1]+f[a-1][b-1]+1;
    while(cin>>k>>n){
        bool flag=0;
        for(int a=0;a<=63;a++) if(f[k][a]>=n){
            flag=1;
            printf("%d\n",a);
            break;
        }
        if(!flag) printf("TLE\n");
    }
    return 0;
}

 

U4699 鸡蛋

标签:

原文地址:http://www.cnblogs.com/shenben/p/5883040.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!