【题解】CF1567C Carrying Conundrum

官方题解的做法根本想不到,讲一下官方题解的做法。

Sol

首先可以发现一个性质,奇数位的数只会进位到奇数位。
偶数位同理。
我们考虑把奇数位的数和偶数位的数单独考虑。
显然,对于一个数 n,分为 2 个非负整数之和只有 n+1 种方案。
记奇数位上的数为 x,偶数位上的数为 y
那么最终的答案即为 (x+1)×(y+1)2
由于不能取 0 所以最终的答案还要减去 2

Code

signed main()
{
	T=read();
	while (T--)
	{
		scanf("%s",st+1); n=strlen(st+1);
		num1=num2=0;
		for (int i=1;i<=n;i+=2)
			num1=num1*10+(st[i]^48);
		for (int i=2;i<=n;i+=2)
			num2=num2*10+(st[i]^48);
		writeln((num1+1)*(num2+1)-2);
	}
}
posted @   dd_d  阅读(164)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
点击右上角即可分享
微信分享提示
主题色彩