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 上海

相关推荐

狸猫换offer:神通广大的互联网
点赞 评论 收藏
分享
HR_丸山彩同学:你的项目描述里,系统设计讲了很多:MemCube是什么、三级存储架构怎么设计、四种遗忘策略分别是什么。这些面试的时候讲没问题,但简历上不需要这么细。 简历要突出的是影响力,不是实现细节。面试官看简历的时候想知道的是「这个项目有多大价值」,不是「这个项目具体怎么实现的」。实现细节是面试时候聊的 怎么改:技术细节可以精简为一句「采用三级存储架构+四种遗忘策略」,把省出来的篇幅用来写影响力。比如:项目有没有开源?有没有写成技术博客?有没有被别人使用过? 校园经历没有任何信息量,任何人都可以写这句话,写了等于没写。更关键的是,你投的是技术岗,校园活动经历本来就不是加分项。如果非要写,必须写出具体的数字和成果。如果你没有这些数字,那就老老实实删掉 「端到端耗时缩减30-40%」要给出确切数字和绝对值。从1000ms降到600ms是降了40%,从100ms降到60ms也是降了40%,但这两个含义完全不一样。其他也是,涉及到数据,准备好证据,口径统一,面试会问 「熟练」「熟悉」「了解」混在一起用,读起来很乱。而且「了解前端需求」最好改成「具备前后端协作经验」
点赞 评论 收藏
分享
评论
2
3
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务