UVA10862 - Connect the Cable Wires(递推 + java的大数)
UVA10862 - Connect the Cable Wires(递推 + java的大数)
题目大意:给你n座房子位于一条直线上,然后仅仅给你一个cable service。要求每座房子都连上有线,方式能够是间接的通过这个房子的直接邻居连接(前提是它的邻居要连上有线),第二种是直接连上cable service也是能够的。
解题思路:把后面的房子编号为1,前面的为n。如果我们要连1号房子,那么它有三种可能。
1、直接和cable service连接,那么就是加上f(n - 1)种(前面的n - 1座房子的组合方式)。
2、和2号房子连接不和cable service连接,那么又是f(n - 1)种。
3、和2号房子链接且和cable service连接,那么这就意味这2号房子不能和cable service链接,否则形成环了。这样就能够把1号和2号看成一个总体,而且和cable service有一条边。这种情况就能够分两种:(1)、不和三号连,加上f(n - 2)。
(2)和三号连,这样情况又回到情况3,说明这个是能够递归的。
所以f(n) = 2 f(n - 1) + f(n - 2) + f(n - 3) + .. + f(1) + 1.(递归到1的时候仅仅有不和1号连接和与1号连接然后1号不和cable service这两种)
相同写出f(n - 1),相减得:f(n) = 3 $*$ f(n - 1) - f(n - 2); (n > 2).
边界f(2) = 3, f(1) = 1;3的2000次方会超过long long的,所以要用大数。
代码:
import java.util.*;
import java.math.*;
import java.io.*;
public class Main {
static BigInteger f[] = new BigInteger[2005];
public static void init() {
f[1] = BigInteger.valueOf(1);
f[2] = BigInteger.valueOf(3);
for (int i = 3; i <= 2000; i++)
f[i] = BigInteger.valueOf(3).multiply(f[i - 1]).subtract(f[i - 2]);
}
public static void main(String args[]) {
Scanner cin = new Scanner(System.in);
int n;
init();
while (true) {
n = cin.nextInt();
if (n == 0)
break;
System.out.println(f[n]);
}
}
}
UVA10862 - Connect the Cable Wires(递推 + java的大数)的更多相关文章
- HOJ 2148&POJ 2680(DP递推,加大数运算)
Computer Transformation Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4561 Accepted: 17 ...
- UVa 1646 (递推 JAVA大数) Edge Case
题意: 有n个点围成一圈,这n个点的匹配就是没有公共点的边集(这些边只能连接一圈中相邻的两点),求所有匹配的个数. 额,我不会分析..=_=|| 算了几个数,找找规律发现它满足斐波那契数列的递推关系, ...
- Tiling(递推+大数)
Description In how many ways can you tile a 2xn rectangle by 2x1 or 2x2 tiles? Here is a sample tili ...
- 【Java】递归递推的应用
利用阶乘公式来计算组合式: 程序设计思想: 根据公式来计算组合数的大小,从键盘输入n,k的值,设计一个计算阶乘的大小,如果输入的数a为1或0,则直接return 1,否则运用递归,计算a-1的阶乘,直 ...
- 穷举算法和递推算法(Java)
穷举算法 概念: 最简单算法,依赖计算机的强大计算能力穷尽每一种可能的情况.穷举算法效率不高,但是适合一些没有明显规律可循的场合. 思想: 在使用穷举算法时,需要明确问题答案的范围,这样才可能在指定范 ...
- 【Java】【高精度】【组合数】【递推】poj1737 Connected Graph
http://blog.csdn.net/sdj222555/article/details/12453629 这个递推可以说是非常巧妙了. import java.util.*; import ja ...
- 算法笔记_091:蓝桥杯练习 递推求值(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 已知递推公式: F(n, 1)=F(n-1, 2) + 2F(n-3, 1) + 5, F(n, 2)=F(n-1, 1) + 3F(n- ...
- Java实现 蓝桥杯VIP 算法训练 步与血(递推 || DFS)
试题 算法训练 步与血 问题描述 有n*n的方格,其中有m个障碍,第i个障碍会消耗你p[i]点血.初始你有C点血,你需要从(1,1)到(n,n),并保证血量大于0,求最小步数. 输入格式 第一行3个整 ...
- Java实现 蓝桥杯 算法提高 递推求值
算法提高 递推求值 时间限制:1.0s 内存限制:256.0MB 问题描述 已知递推公式: F(n, 1)=F(n-1, 2) + 2F(n-3, 1) + 5, F(n, 2)=F(n-1, 1) ...
随机推荐
- hdu3555Bomb(数位dp)
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submi ...
- [SDOI2004]打鼹鼠
...... 心血来潮,手打abs 结果...BZOJ上CE,洛谷上WA... 把宏定义换成函数就过了 显然一个点可以走到另一个点,当且仅当两点鼹鼠出现时间$\leq$两点间距离的曼哈顿距离 显然是D ...
- POJ 1985 求树的直径 两边搜OR DP
Cow Marathon Description After hearing about the epidemic of obesity in the USA, Farmer John wants h ...
- JavaScript中变量的类型
变量的类型是指变量的值所属的数据类型,可以是数值型.字符串型和布尔型等,因为JavaScript是一种弱类型的程序语言,所以可以把任意类型的数据赋值给变量. 下面是一个关于变量类型的例子.在这个例子中 ...
- Visual Studio UI Automation 学习(二)
今天恰好有时间,继续学习了一下UI Automation的知识.看了两篇博客,对UI Automation有了进一步的了解. https://blog.csdn.net/qq_37546891/art ...
- (转)基于MVC4+EasyUI的Web开发框架经验总结(10)--在Web界面上实现数据的导入和导出
http://www.cnblogs.com/wuhuacong/p/3873498.html 数据的导入导出,在很多系统里面都比较常见,这个导入导出的操作,在Winform里面比较容易实现,我曾经在 ...
- C# Cookies设置和读取
public ActionResult Index() { #region 写入Cookies HttpCookie cookie = new HttpCookie("CookieName& ...
- swiper和Navigator组件
<swiper class="index-banner" indicator-dots="{{true}}" autoplay="{{true} ...
- We wanted {"required":["value"]} and you sent ["text","value","id","sessionId"]
重装python pycharm后再次执行以前执行没有问题的Appium脚本报错 We wanted {"required":["value"]} and yo ...
- 重写servlet,可以获取不同的方法
public class BaseServlet extends HttpServlet { @Override public void service(HttpServletRequest requ ...