当前位置: 首页 > news >正文

(C++)字符串相乘

 个人主页:Lei宝啊 

愿所有美好如期而遇


题目链接如下: 

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode-cn.com/problems/multiply-strings/description/

题目

思路

我们首先不能将字符串全部转换为数字,因为存储不下,而且注意也不允许,所以我们应该想到用一个字符串尾部的单位乘一个字符串,然后存储得到的字符串,再由尾部的倒数第二位乘,再存储结果字符串,并且根据位数在结果字符串后补0,最终得到的所有结果字符串相加,就是我们的答案。

字符串相加:(C++)字符串相加

图解 

代码

string multiply(string num1, string num2) {if(num1 == "0" || num2 == "0"){return "0";}int s1 = num1.size();int s2 = num2.size();if(s1 > s2){num1.swap(num2);s1 = num1.size();s2 = num2.size();}int count = 0;string s[201];for(int i=s1-1; i>=0; i--){int ch1 = num1[i] - 48;int add = 0;for(int j=s2-1; j>=0; j--){int ch2 = num2[j] - 48;s[i] += ch2 * ch1 % 10 + 48 + add;add = ch2 * ch1 / 10;     }if(add > 0){s[i] += add + 48;}reverse(s[i].begin(),s[i].end());for(int k=0; k<count; k++){s[i] += '0';}count++;}string result;for(int i=0; i<s1; i++){result = addStrings(result,s[i]);}return result;}
string addStrings(string num1, string num2) {string result;int next = 0;char tmp1 = 0;char tmp2 = 0;while(!num1.empty() || !num2.empty()){if(!num1.empty())tmp1 = num1[num1.size()-1] - 48;elsetmp1 = 0;if(!num2.empty())tmp2 = num2[num2.size()-1] - 48;elsetmp2 = 0;int sum = tmp1 + tmp2 + next;next = sum / 10;sum %= 10;result += (sum+48);if(!num1.empty())num1.erase(num1.end()-1);if(!num2.empty())num2.erase(num2.end()-1);}if(next > 0)result += '1';reverse(result.begin(),result.end());return result;}   

http://www.lryc.cn/news/247902.html

相关文章:

  • 1992-2021年区县经过矫正的夜间灯光数据(GNLD、VIIRS)
  • RK3568笔记六:基于Yolov8的训练及部署
  • 【活动回顾】sCrypt在柏林B2029开发者周
  • 【SpringBoot3+Vue3】六【完】【番外篇】- (0-1临摹)
  • 生成式AI与大语言模型,东软已经准备就绪
  • Python爬虫遇到重定向URL问题时如何解决?
  • 【点云surface】无序点云快速三角化
  • el-select多选下拉框实现全选功能
  • Elasticsearch 聚合查询(Aggregation)详解
  • 数据库其它调优策略
  • 【AI认证笔记】NO.2人工智能的发展
  • Python与设计模式--观察者模式
  • Elasticsearch底层原理分析——新建、索引文档
  • ts实现合并数组对象中key相同的数据
  • C语言--根据成绩判断等级
  • Rust多线程任务,发现有些线程一直获取不到锁【已解决】
  • 【区块链】产品经理的NFT初探
  • 香港服务器减少延迟的几种方法
  • PowerShell命令小记
  • C语言小练
  • Webhook端口中的自签名身份验证
  • CSS预处理器(如Sass或Less):变量、嵌套规则和混合器等高级功能
  • 【Linux】Linux第一个小程序 --- 进度条
  • 每日一练:约瑟夫生者死者小游戏
  • 双指针算法(题目与答案讲解)
  • python服装电商系统vue购物商城django-pycharm毕业设计项目推荐
  • 数据治理技术:研究现状与数据规范
  • 一文彻底理解索引下推
  • Springboot3+vue3从0到1开发实战项目(一)
  • [字符串操作] 有年代的病历单