【笔试训练】day6

1.大数加法

思路:

高精度板子,停留一下都是罪过!

代码:

class Solution {
public:
    
    string solve(string s, string t) {
        vector<int> a;
        vector<int> b;

        for(int i=s.size()-1;i>=0;i--)a.push_back(s[i]-'0');
        for(int i=t.size()-1;i>=0;i--)b.push_back(t[i]-'0');
        if(s.size()==0)a.push_back(0);
        if(t.size()==0)b.push_back(0);

        vector<int> c;
        int tt=0;
        for(int i=0;i<a.size()||i<b.size();i++){
             if(i<a.size())tt+=a[i];
             if(i<b.size())tt+=b[i];

             c.push_back(tt%10);
             tt/=10;
        }
        if(tt)c.push_back(tt);
        string ans="";
        for(int i=c.size()-1;i>=0;i--){
            char u=c[i]+'0';
            ans+=u;
        }
        return ans;
    }
};

2.链表相加(二)

思路:

还是高精度,只不过数组换成了链表。但是换汤不换药,还是先反转一下,从低位开始加减。

在纸上画一下就好了。不过呢建议做链表题的时候多用哨兵节点,这样可以减少处理边界情况。还有就是链表题在传指针作为参数的时候,注意二级指针的问题。

代码:

#define _CRT_SECURE_NO_WARNINGS 1
/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
class Solution {
public:
    ListNode* relist(ListNode** head) {
        ListNode* a = (*head)->next;
        ListNode* pre = *head;
        pre->next = nullptr;
        if (a == nullptr)return *head;
        while (a) {
            //cout<<a->val<<endl;
            ListNode* temp = a->next;
            a->next = pre;
            pre = a;
            if (temp == nullptr)break;
            a = temp;
        }
        //  cout<<a->val<<endl;
        return a;
    }
    ListNode* addInList(ListNode* head1, ListNode* head2) {
        ListNode* a = relist(&head1);

        ListNode* b = relist(&head2);

        ListNode* c = (ListNode*)new ListNode(-1);
        ListNode* p3 = c;
        ListNode* p1 = a;
        ListNode* p2 = b;
        int t = 0;
        while (p1 || p2) {
            if (p1) {
                t += p1->val;
                p1 = p1->next;
            }
            if (p2) {
                t += p2->val;
                p2 = p2->next;
            }
            ListNode* temp = (ListNode*)new ListNode(t % 10);
            p3->next = temp;
            p3 = temp;
            t /= 10;
        }
        if (t) {
            ListNode* temp = (ListNode*)new ListNode(t % 10);
            p3->next = temp;
            p3 = temp;
            t /= 10;
        }
        return relist(&c->next);
    }
};

3.大数相乘

思路:

乘法高精度。比加法稍微多处理一些。两数相乘的结果最大的位数就是这两个数的位数和,比如10*100,最后的结果就是2+3=5位数。所以存答案的数组的空间开多大可以提前算出来。

模拟一下自己做乘法的过程,每次a的第i位乘以b的第j位,其结果一定在c的[i+j]位。

c此时[i+j]里有可能大于10,我们需要进位,进位就是c[i+j+1]=c[i+j]/10。进位之后再更新一下c[i+j]。

最后答案转为字符串。

值得注意的是,高精度乘法得到答案的最高位有可能不是一个一位数,比如2*10,此时的c[0]=10。这里我们用to_string就好了。

哦还有前导0的情况。为什么呢?因为我们存答案的数组c开的是理论上最大的空间,但是实际上可能不会用到这么多。比如一个一位数乘以一个一位数,最大得到一个二位数,我们就开2个int的空间。但是有可能是1*1=1还是一位数,多余的空间里存的0就是前导0.

代码:

#define _CRT_SECURE_NO_WARNINGS 1
class Solution {
public:

    string solve(string s, string t) {
        vector<int> a;
        vector<int> b;
        if (s == "0" || t == "0")return "0";
        for (int i = s.size() - 1; i >= 0; i--)a.push_back(s[i] - '0');
        for (int i = t.size() - 1; i >= 0; i--)b.push_back(t[i] - '0');
        int n = a.size();
        int m = b.size();
        vector<int> c(m + n);
        int tt = 0;
        for (int i = 0; i < a.size(); i++) {
            tt = 0;
            for (int j = 0; j < b.size(); j++) {
                tt = a[i] * b[j];
                c[i + j] += tt;
                // cout<<i*j<<"--"<<c[i*j]<<" ";
                c[i + j + 1] += c[i + j] / 10;
                c[i + j] %= 10;
            }
        }
        int p = c.size() - 1;
        while (c[p] == 0 && p >= 0) {
            p--;
        }
        string ans = "";
        for (int i = p; i >= 0; i--) {
            string k = to_string(c[i]);
            ans += k;
        }
        return ans;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/557702.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AOP

代理模式 提出问题 现有缺陷 假设我们有一个计算类&#xff0c;里面有加减乘除四个方法&#xff0c;现在我们要为这四个方法添加日志&#xff0c;即在方法执行的前后分别输出一句话&#xff0c;这时我们会发现如下缺陷&#xff1a; 1.对核心业务有干扰。核心业务是加减乘除…

Transformer中的位置编码详解

什么是位置编码 位置编码概述 位置编码的目的是为了补充序列的位置信息&#xff0c;这是因为自注意力机制本身不包含位置的概念&#xff08;例如顺序信息&#xff09;。位置编码的具体作用是&#xff0c;对于不同的输入序列成分&#xff0c;赋予其不同的位置标识&#xff0c;确…

C++-命名空间

C 命名空间是一种用于组织代码的机制&#xff0c;可以帮助避免命名冲突&#xff0c;提高代码的可读性和可维护性。命名空间将代码分组到逻辑单元中&#xff0c;允许在不同的代码单元中使用相同的名称而不会产生冲突。 命名空间通过将代码放置在一个命名空间内部来实现。在 C 中…

被Claude3的图生代码技术秀到了,前端开发效率,提升到秒级

被Claude3的图生代码技术秀到了&#xff01;前端开发效率&#xff0c;提升到秒级 上传一张网站图片&#xff0c;用Claude3 生成实现这个网站的代码的教程来啦&#xff01; 在Claude3 的中文网站上一分钟就能实现&#xff0c;生成前端代码。中文网站地址是https://askmanyai.c…

探索 IntelliJ IDEA 2024.1最新变化:全面升级助力编码效率

探索 IntelliJ IDEA 2024.1最新变化&#xff1a;全面升级助力编码效率 文章目录 探索 IntelliJ IDEA 2024.1最新变化&#xff1a;全面升级助力编码效率摘要引言 IntelliJ IDEA 2024.1 最新变化关键亮点全行代码补全 Ultimate对 Java 22 功能的支持新终端 Beta编辑器中的粘性行 …

解决跨域和https不能访问的问题。

本地安装了项目,是一键安装的,安装之后还是apache的web服务器,有个视频服务用的是https的服务,要对这个项目进行二次开发,本地调用没问题,可是别人已调用就跨域。只能本地访问。 现在有两个问题:1.解决跨域问题 2.还要解决https访问的问题。 解决思路,用nginx 的ssl证…

本地项目如何设置https——2024-04-19

问题&#xff1a;由于项目引用了html5-qrcode插件&#xff0c;但是该插件在本地移动端调试时只能使用https访问&#xff0c;所有原本的本地地址是http&#xff0c;就需要改成https以方便调试。 解决方法&#xff1a;使用本地https证书 1&#xff09;从项目文件下打开cmd逐步输…

Springboot配置文件(application.yml)的加载顺序

spring boot 启动会扫描一下位置的application.properties或者application.yml文件作为Spring boot的默认配置文件 file…/config/ file…/ classpath:/config classpath:/ 以上是按照优先级从高到低的顺序&#xff0c;所有位置的文件都会被加载&#xff0c;高优先级配置内容会…

代码随想录算法训练营第四十四天| LeetCode70. 爬楼梯 (进阶)、322. 零钱兑换、279.完全平方数

一、LeetCode 70. 爬楼梯 &#xff08;进阶&#xff09; 题目链接/文章讲解/视频讲解&#xff1a;https://programmercarl.com/0070.%E7%88%AC%E6%A5%BC%E6%A2%AF%E5%AE%8C%E5%85%A8%E8%83%8C%E5%8C%85%E7%89%88%E6%9C%AC.html 状态&#xff1a;已解决 1.思路 这道题跟70.爬楼…

突破“三个九”!离子阱量子计算再创新高

如果把量子计算比作一场球赛&#xff0c;Quantinuum无疑又打了一记漂亮的好球。实际上&#xff0c;结合今年春季在量子体积、逻辑量子比特和布线问题等方面的进展&#xff0c;这个团队已经接近于完成一场完美的比赛。 3月&#xff0c;Quantinuum的研究人员证明了QCCD架构的可扩…

JavaScript 流程控制-循环

一、循环 二、 for 循环 重复执行的语句被称为循环体&#xff0c;能否继续重复执行&#xff0c;取决于循环的终止条件。 由循环体及循环的终止条件组成的语句被称为循环语句 1、语法结构 for 循环 主要用于把某些代码循环若干次&#xff0c;通常跟计数有关 for &#xff08…

springboot结合vue实现文件上传下载功能

紧接着上一次的博客&#xff0c;这次来实现一下文件(主要是图片)的上传和下载功能&#xff0c;上一次的博客如下所示&#xff1a; Springboot集成JWT token实现权限验证-CSDN博客 其实文件的上传和下载功能(后端的部分)&#xff0c;在我之前的博客就已经有写了&#xff0c;所以…

力扣经典150题第三十题:长度最小的子数组

目录 力扣经典150题解析之三十&#xff1a;长度最小的子数组1. 介绍2. 问题描述3. 示例4. 解题思路方法一&#xff1a;滑动窗口 5. 算法实现6. 复杂度分析7. 测试与验证测试用例设计测试结果分析 8. 进阶9. 总结10. 参考文献感谢阅读 力扣经典150题解析之三十&#xff1a;长度最…

重构国内游戏账号登录系统的思考和实践

本期作者 背景 账号登录系统&#xff0c;作为游戏发行平台最重要的应用之一&#xff0c;在当前的发行平台的应用架构中&#xff0c;主要承载的是用户的账号注册、登录、实名、防沉迷、隐私合规、风控等职责。合规作为企业经营的生命线&#xff0c;同时&#xff0c;账号登录作为…

数据结构系列-堆的实现

&#x1f308;个人主页&#xff1a;羽晨同学 &#x1f4ab;个人格言:“成为自己未来的主人~” 堆的实现&#xff0c;其实也就是二叉树的实现&#xff0c;我们在这里是基于数组对其进行实现的&#xff01; typedef struct Heap {HPDataType* a;int size;int capacity; }HP;…

毕业设计做一个linux操作系统怎么样?

毕业设计选择做操作系统的话&#xff0c;不太建议做的规模太大&#xff0c;你可以参考一下Linux内核的代码量&#xff0c;完全从头写的工作量还是挺大的。如果是一行一行从头写&#xff0c;学生期间&#xff0c;一学期写10000-20000行有效代码就很强了&#xff0c;而且还要学习…

【面经】2024春招-云计算后台研发工程师1(3个问题,移动TW等)

【面经】2024春招-云计算后台研发工程师1&#xff08;3个问题&#xff0c;移动&TW等&#xff09; 文章目录 岗位与面经基础1&#xff1a;数据库 & 网络&#xff08;3个问题&#xff09;基础2&#xff1a;系统 & 语法模板3&#xff1a;算法 & 项目&#xff08;移…

探索人工智能绘图的奇妙世界

探索人工智能绘图的奇妙世界 人工智能绘图的基本原理机器之美&#xff1a;AI绘图作品AI绘图对艺术创作的影响未来展望与挑战图书推荐&#x1f449;AI绘画教程&#xff1a;Midjourney使用方法与技巧从入门到精通内容简介获取方式&#x1f449;搜索之道&#xff1a;信息素养与终身…

Timelapse - 2024.04.09 -Win

阅读须知&#xff1a; 探索者安全团队技术文章仅供参考,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作,由于传播、利用本公众号所提供的技术和信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者 本人负责&#xff0c;作者不为此承担任何责任,如…

centos6.5重启docker容器死机问题

概述 近期在整理服务问题&#xff0c;使用docker容器重新部署服务。 过程中有不少坑&#xff0c;主要是系统配置和系统版本的问题。 环境 CentOS release 6.5 (Final) docker version 1.7.1 问题现象 使用restart命令重启docker容器&#xff0c;系统突然卡死&#xff0c…
最新文章