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

网站建设与开发是什么岗位做网站九州科技

网站建设与开发是什么岗位,做网站九州科技,电商修图技巧,商务网站如何推广力扣题目链接 题目本身难度不大,但是后续的一些补充内容还是值得搞清楚的 主要的逻辑如下: 其实本题的目的就是让我们来模拟我们的竖式加法。所以很直观的一个想法就是使用双指针:分别指向两个 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/507357/

相关文章:

  • 昆明市住房和城乡建设局官方网站wordpress 母婴类模板
  • 成品影视app开发制作唐山seo代理商
  • qq刷赞网站推广快速北京h5网页设计
  • 网站建设与管理电子教程网站网站建设
  • 做卖车网站需要什么手续室内装饰设计费收费标准
  • 莆田网站制作价格服装设计网站免费
  • 坂田网站建设公司国家开发公司
  • 河源建设局网站必分享 wordpress主题
  • 自己做的网站跳转到购彩大厅四川省住房和城乡建设厅官网查询
  • 电商网站的支付接入该怎么做呢延安网站建设推广微信网站
  • 百度网站网站建设虚线代码
  • c语言精品网站开发的教学宁波制作网站企业有哪些
  • 沧州做网站的asp网站加速
  • 新手去哪个网站做翻译国外乡村建设网站
  • 手机网站制作架构厦门外贸推广
  • 代备案网站wordpress换头像
  • 河南省建设厅网站地址免费制作的网站
  • 淮南网站开发谷歌商店paypal官网
  • 58网站模板沈阳论坛建站模板
  • 网站设计建设维护与更新福建进入一级战备
  • 建设一个网站项目预算施工企业营销人员培训
  • 新桥企业网站建设做印刷的网站
  • 国内十大网站建设做二手手机的网站有哪些
  • 门户网站建设依据网站模板怎么使用教程
  • 2015年做网站行不行wordpress 做网店
  • 一般网站建设多少钱凡客诚品的经营特色
  • 网业车怎么打车wordpress 手机端优化
  • 网站建设公司顺义成都新冠病最新消息
  • 给人做ppt的网站吗18成年人正能量软件
  • 易语言如何做网站吗点了网站域名会跳转