- 浏览: 318545 次
- 性别:
- 来自: 珠海
文章分类
最新评论
-
xialluyouyue:
Ubuntu下搭建nodejs+express+mongodb环境简单教程 -
k317544294:
Good 陈迪峰
(开源游戏) DOTA音效版 俄罗斯方块 -
基德KID.1412:
su1216 写道竖线代表或者,不代表替换
对哦~ 谢谢你的提 ...
正则表达式中特殊字符的用法(收藏) -
su1216:
竖线代表或者,不代表替换
正则表达式中特殊字符的用法(收藏) -
qiqijianglu:
基德KID.1412 写道qiqijianglu 写道基德KI ...
【高斯消元 求期望】HDU 4418 Time travel
http://acm.hdu.edu.cn/showproblem.php?pid=3818
Sample Input
2
1 2
2 2 4
3 2 4 6
2 2 5
Sample Output
Case 1:
1 5 //答案的第一个数表示后面跟多少个数
Case 2:
2 5 7
题意:每2行的数用输入斐波那契的表示法,例如上面第一个案例,总和就是sum=f(2)+f(2)+f(4)【第一行:2,第二行:2 4】
要求输出sum的斐波那契表示法,sum=f(2)+f(2)+f(4)=f(0)+f(1)+f(2)+f(4)=f(3)+f(4)=f(5),所以答案是1个数,就是5
再仔细观察,找规律:
①显然地:当b-a==1时,f(a)+f(b)=f(b+1),当a-b=1时,f(b)+f(a)=f(a+1)
②当a == b时,f(a) + f(b) = f(a-2) + f(a+1);
证明:
f(a) = f(a-2) + f(a-1);
又因为:f(b) = f(a);
所以f(a)+f(b)=f(a-2)+f(a-1)+f(a)=f(a-2)+f(a+1);
Sample Input
2
1 2
2 2 4
3 2 4 6
2 2 5
Sample Output
Case 1:
1 5 //答案的第一个数表示后面跟多少个数
Case 2:
2 5 7
题意:每2行的数用输入斐波那契的表示法,例如上面第一个案例,总和就是sum=f(2)+f(2)+f(4)【第一行:2,第二行:2 4】
要求输出sum的斐波那契表示法,sum=f(2)+f(2)+f(4)=f(0)+f(1)+f(2)+f(4)=f(3)+f(4)=f(5),所以答案是1个数,就是5
再仔细观察,找规律:
①显然地:当b-a==1时,f(a)+f(b)=f(b+1),当a-b=1时,f(b)+f(a)=f(a+1)
②当a == b时,f(a) + f(b) = f(a-2) + f(a+1);
证明:
f(a) = f(a-2) + f(a-1);
又因为:f(b) = f(a);
所以f(a)+f(b)=f(a-2)+f(a-1)+f(a)=f(a-2)+f(a+1);
#include <iostream> #include <fstream> #include <algorithm> #include <string> #include <set> //#include <map> #include <queue> #include <utility> #include <stack> #include <list> #include <vector> #include <cstdio> #include <cstdlib> #include <cstring> #include <cmath> #include <ctime> #include <ctype.h> using namespace std; #define inf 10000000 //定义无穷大 int ans[405]; int main() { int t, n, i, x, tt, ind, k = 1, j; bool flag; scanf ("%d", &t); while (t--) { tt = 2, ind = 0; while (tt--) { scanf ("%d", &n); for (i = 0; i < n; i++) { scanf ("%d", &x); ans[ind++] = x; //2行输入加入到数组ans } } sort (ans, ans+ind); flag = true; while (flag) //不存在可以合并的2个数则跳出 { flag = false; for (i = 0; i < ind - 1; i++) { if (ans[i] == inf) continue; for (j = i + 1; j < ind; j++) { if (ans[j] == inf) break; if (abs (ans[j] - ans[i]) > 1) continue; if (!flag) //说明存在2个数,他们的差绝对值<=1,即可以合并 flag = true; if (ans[j] - ans[i] == 1) //当b-a==1时,f(a)+f(b)=f(b+1) { ans[ind++] = ans[j] + 1; //生成"f(b+1)" ans[i] = ans[j] = inf;//把f(a)和f(b)变成无穷大,排序时就可以刷下去了 } else if (ans[i] - ans[j] == 1)//当a-b=1时,f(b)+f(a)=f(a+1),同理 { ans[ind++] = ans[i] + 1; ans[i] = ans[j] = inf; } else if (ans[i] == ans[j])//当a == b时,f(a) + f(b) = f(a-2) + f(a+1) { ans[ind++] = ans[i] - 2; //生成2个 ans[ind++] = ans[i] + 1; ans[i] = ans[j] = inf;//相当于删除f(a)和f(b),实现合并操作 } } } sort (ans, ans+ind); //排序,把无穷大刷下去 /*for (i = 0; i < ind; i++) cout << ans[i] << ' '; cout << "\n";*/ } printf ("Case %d:\n", k++); int num = 0; for (i = 0; i < ind; i++) { if (ans[i] == inf) //由于已排序,一旦扫描到无穷大,后面肯定没有合法的数 break; if (ans[i] > 0) num++; //累计结果个数,0不算入斐波那契表示法 } printf ("%d", num); for (i = 0; i < ind; i++) { if (ans[i] == inf) break; if (ans[i] > 0) printf (" %d", ans[i]); } printf ("\n"); } return 0; }
发表评论
-
HDU 4746 Mophues
2013-10-01 17:29 3032莫比乌斯函数完整定义的通俗表达: 1)莫比乌斯函数μ(n ... -
HDU 3221 Brute-force Algorithm
2013-05-04 13:31 1741/* * [题意] * 略 * [解题方法] ... -
UVA 10168 Summation of Four Primes
2013-02-14 21:48 1852/* * [题意] * 将一个数拆成四个素数的和, ... -
UVA 10139 Factovisors
2013-02-09 22:56 2220/* * [题意] * 判断n!是否能被m整除(n ... -
UVA 10104 Euclid Problem
2013-02-09 22:50 1561新手请进:扩展欧几里德入门 /* * ... -
UVA 10006 Carmichael Numbers
2013-02-08 08:27 2492/* * [题意] * 输入n,若满足如下两个条件 ... -
UVA 10110 Light, more light
2013-02-08 08:23 1444/* * [题意本质] * 输入n,如果n的约 ... -
【polya+Euler】HDU 2239 机器人的项链
2012-08-20 13:06 1517KIDx的解题报告 题目 ... -
HDU 1979 Fill the blanks
2012-08-20 12:40 1140KIDx的解题报告 题目链接:http://ac ... -
【生成树计数】HDU 4305 Lightning
2012-08-16 15:45 2702KIDx的解题报告 题 ... -
【扩展欧几里德】SGU 106
2012-05-22 23:57 2407KIDx的解题报告 题目链接:http://acm.s ... -
【数论+容斥】POJ 1091 跳蚤
2012-05-17 13:11 3374KIDx的解题报告 题目链接:http://poj.o ... -
【数论法求一堆数的最小公倍数,结果高达几千位】LOJ 1024 Eid
2012-02-10 16:22 1819KIDx的解题报告 题意:求n个数的最小公倍数,结果很大 ... -
【预处理+卡特兰数+乘法逆元+二分查找】LOJ 1170
2012-01-14 12:57 2299KIDx 的解题报告 题目链接:http://ligh ... -
【快速幂取模】fzu 1752 A^B mod C
2011-11-25 23:32 3679KIDx 的解题报告 参考《算法艺术与信息学竞赛》: 题目 ... -
【高次幂取模的应用】HDU 3609 Up-up
2011-11-25 22:42 2305KIDx 的解题报告 题目很容易看懂:http://acm.h ... -
模线性方程组-非互质中国剩余定理 (更新于2012/5/18)
2011-11-18 19:03 4742KIDx 的解题报告 该专题必备知识:解模线性方程 http: ... -
【素数筛法小结】fzu 1607 + fzu 1753
2011-11-16 23:06 1725KIDx 的解题报告 http://acm.fzu.edu.c ... -
HDU 1410 PK武林盟主
2011-10-02 16:28 1167KIDx 的解题报告 题目链接: http://acm.h ... -
大连2011ACM网络赛【5道水题总结】……很黄很暴力
2011-09-04 18:04 2597KIDx 的解题报告 http://acm.hdu.ed ...
相关推荐
Problem Description 话说,经过了漫长的一个多月,小明已经成长了许多,所以他改了一个名字叫“大明”。 这时他已经不是那个只会做100以内加法的那个“小明”了,现在他甚至会任意长度的正小数的加法。 现在,给你...
本人准备2020年保研机试时刷的题目(虽然最后机试取消了,...来自某中流985,在HDU和vjudge平台上大概刷了400道。本文件地图(excel表格)包含了绝大部分我刷过的题目,笔记中具有思路、代码、总结和心得。 大佬勿入!
- **as easy as a+b** 这个短语在这类题目中通常用来暗示题目难度较低,意味着只需要简单的数学加法操作即可完成任务。 #### 标签:ACM - 标签“ACM”再次强调了本题与ACM程序设计竞赛的相关性,提示读者此题可能...
在C++编程语言中,`new`和`delete`是两个关键的操作符,它们与C语言中的`malloc`和`free`有所不同。`new`不仅分配内存,还会根据指定的类型调用对应的构造函数来初始化对象,而`malloc`仅仅分配内存,不涉及对象的...
在编程竞赛中,杭电(HDU)的在线判题系统提供了许多经典的编程题目,其中包括基础的A+B问题。这类问题通常要求程序能处理两个整数的加法运算,并输出它们的和。尽管看似简单,但这类题目对于初学者来说是理解和掌握...
HDU 300+ AC 代码集合是一个包含超过300个已通过验证的算法解决方案的资源,这些代码主要用于解决各类计算机编程竞赛中的问题。这些竞赛通常由杭州电子科技大学(HDU)主办,旨在提升参赛者的算法设计、编程和问题...
HDU 1022 Train Problem I 附详细思路
HDU(杭州电子科技大学)在线评测系统是许多编程竞赛爱好者和学习者经常访问的平台,它提供了大量的算法题目供用户练习和挑战。这个压缩包文件“HDU 2000-2099 解题报告”显然包含了在这个题号范围内的一些问题、...
acm入门之枚举搜索,学校第一次acm培训,包括枚举及其优化,dfs和bfs
Hdu 1698 Just a Hook 是另一个典型的线段树题目,题目要求我们实现一个数据结构来维护一个数组的区间信息。 Hdu 3584 Cube Hdu 3584 Cube 是一个三维线段树题目,题目要求我们实现一个三维线段树来维护一个三维...
《杭电OnlineJudge 2000-2099解题报告》是针对杭州电子科技大学(HDU)在线评测系统(OnlineJudge)中2000至2099题目的详细解答集锦,主要涵盖了算法分析、编程技巧以及问题解决策略等内容。这份解题报告以CHM...
本文将详细解析该习题集中的前两道习题——“Sum Problem”和“A + B Problem II”,并通过这两道题目的具体分析,帮助初学者提高解题能力和深入理解程序设计的精髓。 首先,让我们来看看“Sum Problem”这个题目。...
具体来说,这个问题是关于 "a+b" 求和的,同时也可能涉及其他数学或编程相关的求解问题。 在编程竞赛或在线判题系统中,"oj题求和"通常指的是提交的代码需要处理一系列整数对 (a, b),并计算它们的和。这类问题通常...
(1000, "A+B Problem", 254527), (1001, "Sum Problem", 152639), # ... 其他题目 ] # 按照AC数量排序 sorted_problems = sorted(problems, key=lambda x: x[2], reverse=True) # 打印排序后的结果 for pid, ...
HDU(杭州电子科技大学在线评测系统)是一个深受程序员喜爱的在线编程练习平台,它提供了丰富的算法题目供用户挑战,帮助他们提升编程技能和算法理解能力。"hdu.rar_hdu"这个压缩包文件很可能是某位程序员整理的他在...
题目大意是:给定 a, b, c, d, k,找到一队 x, y,满足 g(x, y) = k,且 x ∈ [1, b], y ∈ [1, d],问有多少对符合要求的 (x, y)。 思路是:gcd(x, y) == k 解释 x, y 都能被 k 整除,但是能被 k 整除的未必 gcd=k...
【标题】"HDU.rar_hdu_hdu07_com_shownv9b_www.563hdu." 暗示这是一个与HDU(杭州电子科技大学在线编程平台)相关的压缩包,其中可能包含了该平台上的编程竞赛题目或练习题目的源代码。"hdu07"可能是某个特定题目的...
【标题】"HDU_2010.rar"是一个压缩包文件,其中包含了与"HDU 2010"相关的资源,特别是针对"HDU ACM20"比赛的编程题目。"hdu 2010"和"hdu 20"可能是该比赛的不同简称或分类,而"hdu acm20"可能指的是该赛事的第20届...
最后,"HDU+ACM课件"可能是一个综合性的课件集合,涵盖了ACM竞赛的各种主题,包括数据结构、算法、问题解决策略等。这是一份全面的学习资料,对于系统性地学习ACM知识非常有价值。 通过学习这些文件,你可以深入...
- 这个函数接收两个字符串参数`a`和`b`,代表两个待相加的大整数,以及一个整数`fn`作为结果存放的位置索引。 - 函数内部首先计算两个数的长度,然后进行逐位相加,同时考虑进位的情况。 - 结果存储在一个临时的`...