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

龙华做手机网站建设品玩 wordpress主题

龙华做手机网站建设,品玩 wordpress主题,用手机制作网站,成都网络营销搜索推广力扣题目链接 题目本身难度不大,但是后续的一些补充内容还是值得搞清楚的 主要的逻辑如下: 其实本题的目的就是让我们来模拟我们的竖式加法。所以很直观的一个想法就是使用双指针:分别指向两个 num 的末尾。随后就会产生一些问题&#xff1a…

力扣题目链接
题目本身难度不大,但是后续的一些补充内容还是值得搞清楚的

主要的逻辑如下:

  1. 其实本题的目的就是让我们来模拟我们的竖式加法。所以很直观的一个想法就是使用双指针:分别指向两个 num 的末尾。
  2. 随后就会产生一些问题:如何在不进行字符串->整数形式来完成计算:
int x = '9' - '0';

这样就可以完成字符串到整数的隐式转换。

  1. 然后第二个问题,如何完成进位:
    这里就需要和我们的竖式加法一样的逻辑,定义一个 add 来表示进位,每次在按位进行加法的时候,我们需要把这个进位也计算进去。并且每次计算我们也需要计算出当前位是否有进位
int add = 0;
int res = x + y + add;
int add = res / 10;
  1. 最后一个问题,如何处理两个数之间位数不同?
    我们从后往前遍历 num 的时候,如果有位数不同,说明某一个指针已经指向了负数,此时我们就在该位置补0,这个想法也是完全按照竖式加法的思路来的。
int x = i >= 0 ? nums1[i] : 0;
int y = j >= 0 ? nums2[j] : 0;

所以总体CPP代码如下:

class Solution {
public:string addStrings(string num1, string num2) {int i = num1.length() - 1, j = num2.length() - 1, add = 0;string ans = "";while (i >= 0 || j >= 0 || add != 0) {int x = i >= 0 ? num1[i] - '0' : 0;int y = j >= 0 ? num2[j] - '0' : 0;int res = x + y + add;add = res / 10;ans.push_back('0' + res % 10);i--;j--;}reverse(ans.begin(), ans.end());return ans;}
};

补充题:字符串相减(大数相减)

来源于:补充题:字符串相减(大数相减)


首先我们要考虑到两个非负整数相减的结果可能为负。

因此,首先比较两个数的大小。

如果小减大,我们可以将两个参数调换一下位置执行减法,在结果前填上负号即可。(结果为 0 时不加负号)

string subString(string num1, string num2) {string res;if (isLess(num1, num2)) {res = sub(num2, num1);if (res != '0') res.insert(0, '-');} else { res = sub(num1, num2); }return res; 
}

我们可以看到我们需要实现两个函数: isLess(int, int)sub(int, int)

isLess(int, int)

其实思路很简单,长度更长的字符串数一定打;当长度一样的就去比较字典序即可:

bool isLess(string a, string b) {if (a.size() == b.size()) return a < b;return a.size() < b.size();
}

sub(int, int)

其实和加法的差别不大,主要就是把 进位改成 借位

string sub(string a, string b) {string res = "";int i = a.size() - 1, j = b.size() - 1, borrow = 0;while (i >= 0 || j >= 0) {int x = i >= 0 ? (a[i] - '0') : 0; //字符转整数int y = j >= 0 ? (b[j] - '0') : 0; //字符转整数int z = (x - borrow - y + 10) % 10;}
}

好了,写到这里我们不得不聊一聊关键写法之一:
z = (x - borrow - y + 10) % 10
这样的写法更加简洁,相当于:

if (x - borrow - y + 10 < 0) {z = (x - borrow - y + 10) % 10
} else z = x - borrow - y;

好了,我们接着写代码

string sub(string a, string b) {string res = "";int i = a.size() - 1, j = b.size() - 1, borrow = 0;while (i >= 0 || j >= 0) {int x = i >= 0 ? (a[i] - '0') : 0; //字符转整数int y = j >= 0 ? (b[j] - '0') : 0; //字符转整数int z = (x - borrow - y + 10) % 10;res.push_back();borrow = x - borrow - y < 0 ? 1 : 0;i--, j--;}reverse(res.begin(), res.end());//删除前导0,注意边界是 res.size() - 1!,防止当res为"0000"时,删为""的清空int pos = 0;for (pos = 0; pos < res.size() - 1; pos++) {if (res[pos] != '0') break;}return res.substr(pos);
}

这里再谈一个重点:删除前导0
例如,当121-120=001,需要将前面的0删除,得到最终结果1。注意121-121=000这种情况,不要把所有0都删了!

http://www.yayakq.cn/news/848512/

相关文章:

  • 5自己建网站企业网站制作报价单
  • 企业做网站需要什么为什么不建议学电子商务?
  • 网站建设的认识做废钢那个网站好
  • 产品网站怎么做的传奇手游三端互通新开服网站
  • cms傻瓜式建站系统南阳网站网站建设
  • 黑河做网站的企业搭建什么样的平台
  • 大兴网站建设服务公司thinkphp网站后台模板
  • 如何做美食网站设计怎么找做网站平台公司
  • 网站商城注意事项wordpress如何优化网站速度
  • 登录自己网站的后台 wordpress山西2地又检出阳性
  • 网站维护页面模版邯郸住房城乡建设厅网站
  • 微信订阅号做网站wordpress无法创建数据库
  • 动感网站模板wordpress个人
  • 微网站开发周期seo教程
  • 网站右下角广告代码wordpress flatsome
  • 佛山网站建设a068网站建设的课件
  • 不会编程能建网站网站的死链
  • 网站更新维护怎么做企业应该如何进行网站建设
  • excel免费模板网站北京工作室网站建设
  • wordpress 中文tag抖音seo怎么做
  • 加强二级部门网站建设wordpress如何实现
  • 网站布局设计排版河南省监理建设协会网站
  • 中国中小企业网站qq推广软件
  • 中国建设银行下载官方网站电子商务网站建设的规划书
  • 锦州网站seo北京死亡病例最新消息
  • 网站内容规范数据库网页制作教程
  • 新开传奇网站超变建设一个网站引言
  • 如何判断网站开发语言产品设计开发公司
  • 2022做网站还能赚钱吗居然之家装修公司官网
  • 打开网站iis7表单网站