菜鸟学算法之动态规划01

本文是菜鸟学习动态规划的第一篇,从问题描述开始,逐步讲解如何通过代码实现动态规划解决方案,并验证最终结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

按照1-a, 2-b, 3-c, ... ,26-z 的对应关系可以对一串字符串进行编码, 例如 ace 可以编码为 135, 
 但对于135进行解码却有两种可能,其一是ace, 其二是me,  设计一个算法求解一串加密得到的数字
字符串对应着几种原文的可能性?

例:
输入:
135
输出:
2

输入:
1234
输出:
3

代码实现

#include <iostream>
#include <vector>
#include <string>
using namespace std;

int stringDecode(const string& str) {
	int sz = str.size();
	vector<int> vec(sz, 1);
	if (sz < 2) {
		return sz;
	}
	if (('1' == str[0]) || ('2' == str[1] && '6' >= str[1])) {
		vec[1] = 2;
	}
	for (int i = 2; i < sz; i++) {
		vec[i] = vec[i - 1];
		int n = str[i] - '0' + (str[i - 1] - '0') * 10;
		if (n >= 10 && n <= 26) {
			vec[i] += vec[i - 2];
		}
	}
	return vec[sz - 1];
}


int main() {
	while (1) {
		string str;
		cin >> str;
		cout << "可能的加密组合为数:" << stringDecode(str) << endl;
	}
	return 0;
}

结果检验




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值