sicily-1029 Rabbit
一. 题意(0.04s)
每一对成熟的兔子可以生一对兔子,兔子在m个月之后成熟,假设兔子都不会死,计算d个月后一共有多少只兔子。
二. 要高精度加法(用string)
三. 公式:ans[m] = ans[m - 1] + ans[m-M]。
这里M最大值只可能是10,所以开个最大存10个string的数组。把1到N分成数量的M的小组,重复使用数组里面的数据,节省空间。
四. 源代码
- //
- // main.cpp
- // sicily-1029
- //
- // Created by ashley on 14-12-5.
- // Copyright (c) 2014年 ashley. All rights reserved.
- //
- #include <iostream>
- #include <string>
- using namespace std;
- string ans[];
- string clearZeros(string data)
- {
- if (data[] == '') {
- int key = (int) data.length() - ;
- for (int i = ; i < data.length(); i++) {
- if (data[i] != '') {
- key = i;
- break;
- }
- }
- data.erase(, key);
- }
- if (data == "") {
- data = "";
- }
- return data;
- }
- //对位操作
- void countPoint(string &operand1, string &operand2)
- {
- while (operand1.length() < operand2.length()) {
- operand1 = "" + operand1;
- }
- while (operand1.length() > operand2.length()) {
- operand2 = "" + operand2;
- }
- }
- string addition(string addent, string adder)
- {
- //先对位,在加数和被加数前面适当补0,使他们包含相同的位数
- countPoint(addent, adder);
- //前面再补一个0,确定和的最多位数
- addent = "" + addent;
- adder = "" + adder;
- //从低位开始,对应位相加,结果写进被加数中,如果有进位,直接给被加数前一位加1
- for (int i = (int) addent.length() - ; i > ; i--) {
- addent[i] = addent[i] + adder[i] - ;
- if (addent[i] > '') {
- addent[i] = addent[i] - ;
- addent[i - ] = addent[i - ] + ;
- }
- }
- return clearZeros(addent);
- }
- int main(int argc, const char * argv[])
- {
- int month, deadline;
- while (cin >> month >> deadline) {
- if (month == && deadline == ) {
- break;
- }
- string increment;
- increment = "";
- ans[] = "";
- for (int i = ; i <= month - ; i++) {
- ans[i] = addition(ans[i - ], increment);
- }
- for (int i = month; i <= deadline; i++) {
- increment = ans[i % month];
- ans[i % month] = addition(ans[(i - ) % month], increment);
- }
- cout << ans[deadline % month] << endl;
- }
- return ;
- }
sicily-1029 Rabbit的更多相关文章
- 拥抱.NET Core,跨平台的轻量级RPC:Rabbit.Rpc
不久前发布了一篇博文".NET轻量级RPC框架:Rabbit.Rpc",当初只实现了非常简单的功能,也罗列了之后的计划,经过几天的不断努力又为Rabbit.Rpc增加了一大波新特性 ...
- hdu----(1849)Rabbit and Grass(简单的尼姆博弈)
Rabbit and Grass Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 在 Windows 上安装Rabbit MQ 指南
rabbitMQ是一个在AMQP协议标准基础上完整的,可服用的企业消息系统.他遵循Mozilla Public License开源协议.采用 Erlang 实现的工业级的消息队列(MQ)服务器. Ra ...
- .NET轻量级RPC框架:Rabbit.Rpc
最近准备写一个.NET的管理平台应用在公司,由于存在大量的Client => Server,Server => Client的请求需求在加上之前一直接触了解过RpcClient组件的开发, ...
- sicily 中缀表达式转后缀表达式
题目描述 将中缀表达式(infix expression)转换为后缀表达式(postfix expression).假设中缀表达式中的操作数均以单个英文字母表示,且其中只包含左括号'(',右括号‘)’ ...
- sicily 1934. 移动小球
Description 你有一些小球,从左到右依次编号为1,2,3,...,n. 你可以执行两种指令(1或者2).其中, 1 X Y表示把小球X移动到小球Y的左边, 2 X Y表示把小球X移动到小球Y ...
- 古典问题rabbit
/**古典问题: * 有一对兔子,从出生后第三个月起每个月都生一对兔子, * 小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死, * 问每个月的兔子总数为多少? * 程序分析:兔子的规律为数列: ...
- Error: unable to connect to node rabbit@mail: nodedown
某天,开启一个应用时,发现连接rabbitmq失败,本来想用rabbitmqctl来查看队列,结果提示“Error: unable to connect to node rabbit@mail: no ...
- HDU-4057 Rescue the Rabbit(AC自动机+DP)
Rescue the Rabbit Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- .NET 平台下的插件化开发内核(Rabbit Kernel)-转
什么是RabbitHub? RabbitHub 是专门针对 .NET 平台所设计.研发的一套相对完整的插件开发框架,它是由一个内核两大框架多个组件及一系列的开发时支持而构成. RabbitHub 架构 ...
随机推荐
- php7 不向后的兼容的变更
php7 不向后的兼容的变更 在php7中,很多致命错误以及可恢复的致命错误,都被转换为异常来处理了. 这些异常继承自Error类,此类实现了Throwable接口(所有异常都实现了这个基础接口) 这 ...
- C语言复杂的函数指针声明
复习C语言ING,发现复杂的函数指针声明看不懂,百度半天终于略知一二. 讲的比较详细的一篇blog: http://blog.csdn.net/megaboy/article/details/4827 ...
- Java判断字符串是否为空的三种方法
方法一: 最多人使用的一个方法, 直观, 方便, 但效率很低.1: if(s == null || s.equals("")); 方法二: 比较字符串长度, 效率高, 是我知道的最 ...
- asp.net core + angular2
asp.net core + angular2 的环境配置 国内整个对 asp.net core 和 angular2这些新出来的关注度不是太好.跟国外比很大差距. 我在试着去做这个整合的时候也碰到 ...
- 使用Ramdisk 加速 Visualstudio 编译调试
一般来说ASP.NET在执行的时候,会先动态编译在目录 C:\Windows\Microsoft.NET\Framework64\版本\Temporary ASP.NET Files 由于每次修改程序 ...
- poj2656---求一列数中最大数的序数而且在前面输入的更优先
#include<stdio.h> #include<stdlib.h> int main() { int n,i; while(scanf("%d",&a ...
- mongoose的populate的使用方法;
LotteryReceiveRecord.find({"lottery":req.params.id}).populate("user lottery").ex ...
- 【转】Loss Function View
感谢原文作者!原文地址:http://eletva.com/tower/?p=186 一.Loss Function 什么是Loss Function?wiki上有一句解释我觉得很到位,引用一下:Th ...
- Problem 2128 最长子串(kmp+strstr好题经典)
Problem 2128 最长子串 Accept: 134 Submit: 523Time Limit: 3000 mSec Memory Limit : 65536 KB Probl ...
- WebStorm 7.0 注冊码
经測试 WebStorm 6 7均能够使用例如以下注冊码,简直就是神key啊! WebStorm 6.0 7.0 注冊码 User Name: EMBRACE License Key: ===== ...