10.09中金所笔试

长整数乘法

给两个字符串整数,返回其乘积(直接类型转换会overflow)

string multiply(string str1, string str2)
{
	if (str1.empty() || str2.empty())
		return "";

	vector<int> vec1(str1.length(), 0);
	vector<int> vec2(str2.length(), 0);
	
	//将两个长整数翻转保存在数组中
	for (size_t i = 0; i < str1.length(); ++i)
		vec1[str1.length() - 1 - i] = str1[i] - '0';
	for (size_t i = 0; i < str2.length(); ++i)
		vec2[str2.length() - 1 - i] = str2[i] - '0';
		
	//构造一个(n+1) + (m+1)的数组用来保存其相乘结果。
	int n = vec1.size() + 1 + vec2.size() + 1;
	vector<int> res(n, 0);
	
	//将两个长整数单个位进行相乘并加上对应位置数然后存储
	for (size_t i = 0; i < vec1.size(); ++i) {
		for (size_t j = 0; j < vec2.size(); ++j) {
			res[i + j] = res[i + j] + vec1[i] * vec2[j];
		}
	}
	
	//遍历整个res数组进行进位操作。
	int carry = 0; //进位
	for (size_t i = 0; i < n; ++i)
	{
		int temp = res[i] + carry;
		res[i] = temp % 10;
		carry = temp / 10;
	}

	//去掉多余的0然后转为字符串存储
	string ret;
	while (n-- > 0) {
		if (res[n] != 0)
			break;
	}

	while (n >= 0) {
		char ch = res[n--] + '0';
		ret.push_back(ch);
	}

	if (ret.empty())
		ret = "0";

	return ret;
}
————————————————
版权声明:本文为CSDN博主「Wkingbai」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_36291615/article/details/126732285
全部评论
这道题我一开始写半天没搞定 然后他说不能用bigdicimal 直接bigdicimal秒了
1 回复 分享
发布于 2023-10-10 02:12 江苏
懒得写直接python秒了,面试官问我怎么看待自己的笔试
点赞 回复 分享
发布于 2023-10-17 14:14 浙江
我用pyhton一行写出来算嘛 😂
点赞 回复 分享
发布于 2023-10-16 10:58 上海

相关推荐

1个小白:可以考虑投一下字节
点赞 评论 收藏
分享
03-28 19:11
铜陵学院 C++
有礼貌的山羊追赶太阳:太典了,连笔试都没有开始就因为HC满了而结束了,而且还卡你不让你再投其他部门的。
点赞 评论 收藏
分享
评论
2
3
分享

创作者周榜

更多
牛客网
牛客企业服务