- 浏览: 320472 次
- 性别:
- 来自: 珠海
-
文章分类
最新评论
-
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 3045莫比乌斯函数完整定义的通俗表达: 1)莫比乌斯函数μ(n ... -
HDU 3221 Brute-force Algorithm
2013-05-04 13:31 1752/* * [题意] * 略 * [解题方法] ... -
UVA 10168 Summation of Four Primes
2013-02-14 21:48 1861/* * [题意] * 将一个数拆成四个素数的和, ... -
UVA 10139 Factovisors
2013-02-09 22:56 2238/* * [题意] * 判断n!是否能被m整除(n ... -
UVA 10104 Euclid Problem
2013-02-09 22:50 1576新手请进:扩展欧几里德入门 /* * ... -
UVA 10006 Carmichael Numbers
2013-02-08 08:27 2505/* * [题意] * 输入n,若满足如下两个条件 ... -
UVA 10110 Light, more light
2013-02-08 08:23 1450/* * [题意本质] * 输入n,如果n的约 ... -
【polya+Euler】HDU 2239 机器人的项链
2012-08-20 13:06 1534KIDx的解题报告 题目 ... -
HDU 1979 Fill the blanks
2012-08-20 12:40 1155KIDx的解题报告 题目链接:http://ac ... -
【生成树计数】HDU 4305 Lightning
2012-08-16 15:45 2709KIDx的解题报告 题 ... -
【扩展欧几里德】SGU 106
2012-05-22 23:57 2424KIDx的解题报告 题目链接:http://acm.s ... -
【数论+容斥】POJ 1091 跳蚤
2012-05-17 13:11 3391KIDx的解题报告 题目链接:http://poj.o ... -
【数论法求一堆数的最小公倍数,结果高达几千位】LOJ 1024 Eid
2012-02-10 16:22 1832KIDx的解题报告 题意:求n个数的最小公倍数,结果很大 ... -
【预处理+卡特兰数+乘法逆元+二分查找】LOJ 1170
2012-01-14 12:57 2310KIDx 的解题报告 题目链接:http://ligh ... -
【快速幂取模】fzu 1752 A^B mod C
2011-11-25 23:32 3686KIDx 的解题报告 参考《算法艺术与信息学竞赛》: 题目 ... -
【高次幂取模的应用】HDU 3609 Up-up
2011-11-25 22:42 2314KIDx 的解题报告 题目很容易看懂:http://acm.h ... -
模线性方程组-非互质中国剩余定理 (更新于2012/5/18)
2011-11-18 19:03 4755KIDx 的解题报告 该专题必备知识:解模线性方程 http: ... -
【素数筛法小结】fzu 1607 + fzu 1753
2011-11-16 23:06 1734KIDx 的解题报告 http://acm.fzu.edu.c ... -
HDU 1410 PK武林盟主
2011-10-02 16:28 1177KIDx 的解题报告 题目链接: http://acm.h ... -
大连2011ACM网络赛【5道水题总结】……很黄很暴力
2011-09-04 18:04 2603KIDx 的解题报告 http://acm.hdu.ed ...
相关推荐
Problem Description 话说,经过了漫长的一个多月,小明已经成长了许多,所以他改了一个名字叫“大明”。 这时他已经不是那个只会做100以内加法的那个“小明”了,现在他甚至会任意长度的正小数的加法。 现在,给你...
本文将详细解析该习题集中的前两道习题——“Sum Problem”和“A + B Problem II”,并通过这两道题目的具体分析,帮助初学者提高解题能力和深入理解程序设计的精髓。 首先,让我们来看看“Sum Problem”这个题目。...
(1000, "A+B Problem", 254527), (1001, "Sum Problem", 152639), # ... 其他题目 ] # 按照AC数量排序 sorted_problems = sorted(problems, key=lambda x: x[2], reverse=True) # 打印排序后的结果 for pid, ...
根据描述,这道题目是“A+B PROBLEM”的一种变形,主要考察的是循环结构和基本的输入输出操作。对于初学者来说,通过这道题目可以加深对C语言基础语法的理解,并提高解决实际问题的能力。 #### 题目分析 题目要求...
- **1089 A+B for Input-Output Practice (I)**: Given two integers `a` and `b`, calculate their sum. This problem focuses on input/output operations and basic arithmetic. - **1090 A+B for Input-Output...
### hdu题目分类知识点概述 本篇将对“hdu题目分类”中提及的各种类型问题进行详细介绍,旨在帮助读者更好地理解这些题目所涉及的核心概念和技术点,并为编程竞赛中的实战训练提供参考。以下是对每道题目的具体分析...
下面以一道非常基础的题目“A+B Problem”为例,来展示如何用C和C++来解答。 ##### 题目描述 计算两个整数a和b的和。 **输入** 每行包含一对整数a和b,以空格分隔。 **输出** 对于每对输入的整数a和b,输出它们的...
return a.x * b.x + a.y * b.y; } ``` - **叉积计算**: ```cpp double cross(Vector a, Vector b) { return a.x * b.y - a.y * b.x; } ``` ##### 1.4 扩展变型 - 如何处理三维空间中的几何问题? - 针对...