网站首页 > 技术教程 正文
学习C++从娃娃抓起!记录下洛谷C++学习和备考过程中的题目,记录每一个瞬间。
附上汇总贴:洛谷刷题C++语言 | 汇总_热爱编程的通信人的博客-CSDN博客
【题目描述】
对于一个递归函数 w(a,b,c)
- 如果 a≤0 或 b≤0 或 c≤0 就返回值1。
- 如果 a>20 或 b>20 或 c>20 就返回 w(20,20,20)
- 如果 a<b 并且 b<c 就返回w(a,b,c?1)+w(a,b?1,c?1)?w(a,b?1,c)。
- 其它的情况就返回 w(a?1,b,c)+w(a?1,b?1,c)+w(a?1,b,c?1)?w(a?1,b?1,c?1)
这是个简单的递归函数,但实现起来可能会有些问题。当 a,b,c 均为 15 时,调用的次数将非常的多。你要想个办法才行。
注意:例如 w(30,?1,0) 又满足条件 1 又满足条件 2,请按照最上面的条件来算,答案为 1。
【输入】
会有若干行。
并以 ?1,?1,?1 结束。
【输出】
输出若干行,每一行格式:
w(a, b, c) = ans
注意空格。
【输入样例】
1 1 1
2 2 2
-1 -1 -1
【输出样例】
w(1, 1, 1) = 2
w(2, 2, 2) = 4
【代码详解】
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
LL a, b, c;
int w1[25][25][25]={0};
int w(LL a, LL b, LL c) {
if (a<=0 || b<=0 || c<=0) return 1;
if (a>20 || b>20 || c>20) return w(20, 20, 20);
if (w1[a][b][c]!=0) return w1[a][b][c];
if (a<b && b<c) {
w1[a][b][c] = w(a, b, c-1) + w(a, b-1, c-1) - w(a, b-1, c);
} else {
w1[a][b][c] = w(a-1, b, c) + w(a-1, b-1, c) + w(a-1, b, c-1) - w(a-1, b-1, c-1);
}
return w1[a][b][c];
}
int main()
{
while (true) {
cin >> a >> b >> c;
if (a==-1 && b==-1 && c==-1) break;
printf("w(%lld, %lld, %lld) = %d\n", a, b, c, w(a,b,c));
}
return 0;
}
【运行结果】
1 1 1
w(1, 1, 1) = 2
2 2 2
w(2, 2, 2) = 4
-1 -1 -1
猜你喜欢
- 2024-10-05 七律 巴夫洛谷的春天 巴夫洛logo
- 2024-10-05 「洛谷日报第31期」dijkstra详解 dijkstra floyd
- 2024-10-05 「洛谷日报第27期」点分治略解 点分什么意思
- 2024-10-05 洛谷刷题C++语言 | P1010 幂次方 c++次幂怎么输入
- 2024-10-05 洛谷刷题C++语言 | P1036 选数 洛谷p5714答案c语言
- 2024-10-05 洛谷刷题C++语言 | P1012 拼数 洛谷p5714答案c语言
- 2024-10-05 洛谷刷题C++语言 | P3392 涂国旗 c语言画国旗代码
- 2024-10-05 「洛谷日报第20期」浅谈基础根号算法——分块
- 2024-10-05 洛谷刷题C++语言 | P1102 A-B数对
- 2024-10-05 洛谷刷题C++语言 | P1443 马的遍历
你 发表评论:
欢迎- 05-1613步震撼淘宝大促闪光裂纹破墙立体字PS制作教程
- 05-16AI教程 | 绘制扁平的萌萌哒图标
- 05-160基础学平面设计所需了解的基础常识汇总
- 05-16自学平面设计需要多长时间?十六年职业设计总监告诉你
- 05-16平面设计都要学习哪些内容?
- 05-16李涛PS教程 高手之路PS教程 合成教程 —制作一个小星球
- 05-16Illustrator实例教程:制作炫酷的漩涡效果
- 05-16Illustrator实例教程:利用混合工具制作一朵炫酷的花
- 最近发表
- 标签列表
-
- sd分区 (65)
- raid5数据恢复 (81)
- 地址转换 (73)
- 手机存储卡根目录 (55)
- tcp端口 (74)
- project server (59)
- 双击ctrl (55)
- 鼠标 单击变双击 (67)
- debugview (59)
- 字符动画 (65)
- flushdns (57)
- ps复制快捷键 (57)
- 清除系统垃圾代码 (58)
- web服务器的架设 (67)
- 16进制转换 (69)
- xclient (55)
- ps源文件 (67)
- filezilla server (59)
- 句柄无效 (56)
- word页眉页脚设置 (59)
- ansys实例 (56)
- 6 1 3固件 (59)
- sqlserver2000挂起 (59)
- vm虚拟主机 (55)
- config (61)
本文暂时没有评论,来添加一个吧(●'◡'●)