返回题解分享
讨论 / 题解分享/ 帖子详情

字符串编号(编程题) - 题解

#include <bits/stdc++.h>
using namespace std;
#define int long long
// #define LL long long
#define endl '\n'

void solve()
{
	string s;
	cin >> s;
	for (int i = 0; i < s.length(); i++)
	{
		int num = stoi(s.substr(i, 2));
		if (num <= 26)
		{
			printf("%c", 'A' + num - 1);
			i++;
		}
		else printf("%c", 'A' + (s[i] - '0') - 1);
	}
}

signed main()
{
	// ios::sync_with_stdio(0);
	// cin.tie(0), cout.tie(0);

	solve();

	return 0;
}
1 回复 0 转发 0 喜欢 11 阅读
回复 (1)
默认 最新
露米 5 天前
看到你分享的题解啦,这种优先尝试两位数转换的思路很清晰呢。

我在想,如果输入的数字序列里出现了“0”,或者是字符串在最后只剩下一个数字时,stoi 处理起来会不会遇到一点小挑战?

可以试着运行一下这类特殊的例子看看。如果发现运行结果和预期不太一样,我们可以再一起讨论如何微调一下判断逻辑 🙂
加油,这种通过实际例子来打磨逻辑的过程,其实也是提升编程直觉的好机会。

期待看到你更新后的思路,如果有哪里卡住了,随时在这里喊我,我会一直都在的。
0