笨拙的数字

老师把某个不超过10^9的10进制正整数N分别转换成2进制A和3进制B写在黑板上。但有学生恶作剧,悄悄的把A中的一位修改,同时也把B中的一位修改,看上去还是合法的2进制和3进制。

比如N=14,它正确的2进制表示为:1110,但学生修改后,可能的结果是:0110、1111..等。注意:可能有前导0。

现在老师请你编程找出原来的那个10进制的正整数N。

输入格式

*第1行:N的2进制表示,有一位数字不正确。

*第2行:N的3进制表示,有一位数字不正确。

数据保证有唯一的解

输出格式

*第1行:N的正确值。

输入/输出例子1

输入:

1010

212

输出:

14

样例解释

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
long long change(string s,int base)
{
	long long ans=0;
	int len=s.size();
	for(int i=0;i<len;i++){
		ans=ans*base+(s[i]-'0');
	}
	return ans;
}
int main()
{
	string str2,str3;
	cin>>str2>>str3;
	int len2=str2.size();
	int len3=str3.size();
	for(int i=0;i<len2;i++)
	{
		string temp2=str2;
		if(str2[i]=='0') temp2[i]='1';
			else temp2[i]='0';
		long long ans2=change(temp2,2);
		for(int j=0;j<len3;j++){
			string temp3=str3;
			for(int k=0;k<3;k++){
					int p3=str3[j]-'0';
					if(p3==k) continue;
					temp3[j]=k+'0';
					long long ans3=change(temp3,3);
					if(ans2==ans3)
					{
						cout<<ans2<<endl;
						return 0;
					}	
				}
			}
	}	
	return 0;
}
相关推荐
kyle~7 分钟前
C++20--- concept 关键字 为模板参数提供了编译期可验证的约束机制
运维·c++
CS_浮鱼16 分钟前
【C++进阶】异常
开发语言·c++
努力学算法的蒟蒻21 分钟前
day14(11.14)——leetcode面试经典150
算法·leetcode
QT 小鲜肉25 分钟前
【C++基础与提高】第十一章:面向对象编程进阶——继承与多态
java·linux·开发语言·c++·笔记·qt
艾莉丝努力练剑25 分钟前
【C++:封装红黑树】C++红黑树封装实战:从零实现MyMap与MySet
c++·stl·set·map·红黑树·平衡二叉树
让我们一起加油好吗40 分钟前
【数据结构】并查集(操作详解 + 模板 + 练习)
数据结构·算法·并查集·洛谷
PenguinLeee43 分钟前
KKT条件:对偶问题、KKT条件以及内点法
算法·凸优化
序属秋秋秋1 小时前
《Linux系统编程之进程基础》【进程入门】
linux·运维·c语言·c++·进程·系统编程·fork
点云SLAM1 小时前
Boost库中Boost.PropertyTree使用和实战示例
开发语言·c++·josn·boost库·参数读取
晨非辰1 小时前
【数据结构】排序详解:从快速排序分区逻辑,到携手冒泡排序的算法效率深度评测
运维·数据结构·c++·人工智能·后端·深度学习·排序算法