1201. 【高精度练习】蜜蜂路线

题目描述

一只蜜蜂在图5.1-2所示的数字蜂房上爬动,已知它只能从标号小的蜂房爬到标号大的相邻蜂房,

现在问你:蜜蜂从蜂房M开始爬到蜂房N,l≤M

输入

M,N的值。

输出

一个数表示爬行路线种数。

样例输入

复制代码
1 14

样例输出

复制代码
377

代码:

cpp 复制代码
#include <stdio.h>
#include <string>
#include <algorithm>
using namespace std;
typedef string Number;

Number Map[100000];
#define ONE string("1")
#define Rev(a) reverse(a.begin(), a.end())
#define Get(a) ((a) - '0')
int x, y;
Number add(Number a, Number b) // 计算a+b
{
	Rev(a), Rev(b);
	size_t Size1 = a.size(), Size2 = b.size();
	Number ans;
	int carry = 0;
	for (size_t i = 0; i < Size1 || i < Size2; i++)
	{
		int addsum = carry;
		carry = 0;
		if (i < Size1) addsum += Get(a[i]);
		if (i < Size2) addsum += Get(b[i]);
		if (addsum >= 10) addsum -= 10, carry = 1;
		ans.push_back(addsum + '0');
	}
	if (carry) ans.push_back('1');
	Rev(ans);
	return ans;
}
int main()
{
	int m, n;
	scanf("%d%d", &m, &n);
	
	Map[m] = ONE;
	if (m + 1 <= n) Map[m + 1] = ONE;
	for (int i=m+2;i<=n;i++) Map[i] = add(Map[i - 1], Map[i - 2]);
	printf("%s",Map[n].c_str());
	return 0;
}
相关推荐
alphaTao3 小时前
LeetCode 每日一题 2026/1/26-2026/2/1
算法·leetcode
我能坚持多久3 小时前
D20—C语言文件操作详解:从基础到高级应用
c语言·开发语言
txinyu的博客3 小时前
解析muduo源码之 ThreadLocal.h
c++
橘子师兄3 小时前
C++AI大模型接入SDK—ChatSDK封装
开发语言·c++·人工智能·后端
Christo33 小时前
TFS-2026《Fuzzy Multi-Subspace Clustering 》
人工智能·算法·机器学习·数据挖掘
上天_去_做颗惺星 EVE_BLUE4 小时前
Docker高效使用指南:从基础到实战模板
开发语言·ubuntu·docker·容器·mac·虚拟环境
2401_857683544 小时前
C++中的原型模式
开发语言·c++·算法
s1hiyu4 小时前
C++动态链接库开发
开发语言·c++·算法
(❁´◡`❁)Jimmy(❁´◡`❁)4 小时前
CF2188 C. Restricted Sorting
c语言·开发语言·算法
We་ct4 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript