尊享面试100题

news2024/9/22 12:40:48

题目624:数组列表的最大距离(NO)

  • 解题思路:记录每个数组的最大最小值,循环判断最大距离。

给定 m 个数组,每个数组都已经按照升序排好序了。

现在你需要从两个不同的数组中选择两个整数(每个数组选一个)并且计算它们的距离。两个整数 a 和 b 之间的距离定义为它们差的绝对值 |a-b| 。

返回最大距离。

class Solution {
public:
    int maxDistance(vector<vector<int>>& arrays) {
        //这题的做题思路其实就是遍历每个数组,记录数组的最大最小值

        //先记录第一组的最大最小值
        //.back()是获取最后一个值
        int max_value=arrays[0].back();
        int min_value=arrays[0][0];

        int max_Distance=0;

        //从第二个数组开始遍历
        //这里可以是可以进入for循环的,因为题目限制了
        //这里有个限制,最大最小值不能再同一个数组中
        for(int i=1;i<arrays.size();i++)
        {
            //当前数组的最大最小值
            int current_min=arrays[i][0];
            int current_max=arrays[i].back();

            max_Distance=max(max_Distance,abs(current_max-min_value));
            max_Distance=max(max_Distance,abs(current_min-max_value));

            //更新最大最小值
            max_value=max(current_max,max_value);
            min_value=min(current_min,min_value);

        }

        return max_Distance;


    }
};

题目280:摆动排序(YES)

  • 解题思路:这里有规律,排序后再指定位置插入。

给你一个的整数数组 nums, 将该数组重新排序后使 nums[0] <= nums[1] >= nums[2] <= nums[3]…

输入数组总是有一个有效的答案。

class Solution {
public:
    void wiggleSort(vector<int>& nums) {
        //我发现了其中的规律,他是排序后按位置插入的
        sort(nums.begin(),nums.end());
        vector<int>ans=nums;

        int size=ans.size();

        int count=0;
        for(int i=0;i<size;i++)
        {
            if(i%2==0)
            {
                //偶数的不用变
                nums[i]=ans[count];
            }else
            {
                //奇数要变
                nums[i]=ans[size-(count+1)];
                count++;
            }
            
        }


    }
};

题目1056:易混淆数(NO)

  • 解题思路:按照题目的思路,讲所有的数反转再进行比较。

给定一个数字 N,当它满足以下条件的时候返回 true:

原数字旋转 180° 以后可以得到新的数字。

如 0, 1, 6, 8, 9 旋转 180° 以后,得到了新的数字 0, 1, 9, 8, 6 。

2, 3, 4, 5, 7 旋转 180° 后,得到的不是数字。

易混淆数 (confusing number) 在旋转180°以后,可以得到和原来不同的数,且新数字的每一位都是有效的。

class Solution {
public:
    bool confusingNumber(int n) {
        //这题的解题思路是按照题目的意思走,比较旋转反转后是否相同

        //用哈希表来表示旋转后的数
        unordered_map<char,char>map=
        {
            {'0','0'},
            {'1','1'},
            {'9','6'},
            {'8','8'},
            {'6','9'}
        };
        string ret=to_string(n);
        string ans="";//最终结果

        for(char c:ret)
        {
            if(map.find(c)==map.end())
            {
                //存在不能反转的返回false
                return false;
            }
            ans=map[c]+ans;//反转的数放在最前面
        }

        return ans!=ret;

        

    }

};

题目1427:字符串的左右移(YES)

  • 解题思路:根据题目的思路,模拟出来就行。

给定一个包含小写英文字母的字符串 s 以及一个矩阵 shift,其中 shift[i] = [direction, amount]:

direction 可以为 0 (表示左移)或 1 (表示右移)。
amount 表示 s 左右移的位数。
左移 1 位表示移除 s 的第一个字符,并将该字符插入到 s 的结尾。
类似地,右移 1 位表示移除 s 的最后一个字符,并将该字符插入到 s 的开头。
对这个字符串进行所有操作后,返回最终结果。

class Solution {
public:
    string stringShift(string s, vector<vector<int>>& shift) {
        //这种最常规的方法就是根据题目的思路进行移动
        for(int i=0;i<shift.size();i++)
        {
            for(int j=0;j<shift[i][1];j++)
            {
                //移动的位数
                if(shift[i][0]==0)
                {
                    //左移
                    char c=s[0];
                    //从0位置开始删除1个
                    s.erase(0,1);
                    s=s+c;
                }else
                {
                    //右移
                    char c=s[s.size()-1];
                    s.erase(s.size()-1,1);
                    s=c+s;
                }
            }
        }

        return s;
    }
};

题目161:相隔为1的编辑距离(NO)

  • 解题思路:这题也是要迎合这题目的思路,首先就是要将情况分清楚,大于1的必然不行,后面就是对长度差等于0和等于1的情况进行单独的处理就行。方法其实是相似的。

给定两个字符串 s 和 t ,如果它们的编辑距离为 1 ,则返回 true ,否则返回 false 。

字符串 s 和字符串 t 之间满足编辑距离等于 1 有三种可能的情形:

往 s 中插入 恰好一个 字符得到 t
从 s 中删除 恰好一个 字符得到 t
在 s 中用 一个不同的字符 替换 恰好一个 字符得到 t

class Solution {
public:
    bool isOneEditDistance(string s, string t) {

        //这题的难点在于你要将情况分析清楚
        //1.长度差大于1的必然是不行的
        //2.长度差等于1或者为0这是两种可能可以编辑的情况

        //这里全局默认s<t
        int len_s=s.size();
        int len_t=t.size();

        if(abs(len_s-len_t)>1)
        {
            return false;
        }

        //这里筛选下来的都是有可能的,先切换
        if(len_s>len_t)
        {
            swap(s,t);
            swap(len_s,len_t);
        }

        if(len_s==len_t)
        {
            //相等的情况
            bool check=false;
            for(int i=0;i<len_s;i++)
            {
                if(s[i]!=t[i])
                {
                    if(check)
                    {
                        //再次出现不相等就是错误的
                        return false;
                    }
                    //出现一个不相等
                    check=true;
                }
            }

            return check;
        }else
        {
            //差值为1的情况

            //其实和上面的非常相似,就是要找到一个不相等的
            int i=0;
            int j=0;
            for(;i<len_s&&j<len_t;)
            {
                if(s[i]==t[j])
                {
                    //都相等的情况
                    i++;
                    j++;
                }else
                {
                    //头一次找到不相等的
                    if(i==j)
                    {
                        //第一次不相等是允许的
                        j++;
                    }else
                    {
                        return false;
                    }
                }
            }

            return true;
        }

    }
};

题目186:反转字符串中的单词(NO)

  • 解题思路:先反转整体,再反转单个单词。

给你一个字符数组 s ,反转其中 单词 的顺序。

单词 的定义为:单词是一个由非空格字符组成的序列。s 中的单词将会由单个空格分隔。

必须设计并实现 原地 解法来解决此问题,即不分配额外的空间。

class Solution {
public:
     void reverseWords(vector<char>& s) {  
        // 1. 反转整个字符数组  
        reverseRange(s, 0, s.size() - 1);  
        
        // 2. 逐个反转每个单词  
        int start = 0;  
        while (start < s.size()) {  
            int end = start;  
            // 找到单词的结束位置  
            while (end < s.size() && s[end] != ' ') {  
                end++;  
            }  
            // 反转当前单词  
            reverseRange(s, start, end - 1);  
            // 移动到下一个单词  
            start = end + 1;  
        }  
    }  
    
private:  
    void reverseRange(vector<char>& s, int start, int end) {  
        while (start < end) {  
            swap(s[start], s[end]);  
            start++;  
            end--;  
        }  
    } 
};

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

yolov8道路缺陷检测-道路坑洞检测-道路裂缝检测

路面裂缝检测是计算机视觉在基础设施维护中的一个重要应用。使用 YOLOv8 进行路面裂缝检测的过程与绝缘子检测类似&#xff0c;包括数据准备、模型训练和部署。下面是一个详细的流程&#xff0c;包括代码示例。 1. 数据准备 数据收集 图像采集&#xff1a;通过无人机、车载摄…

电脑文件防泄密软件哪个好?这六款软件建议收藏【精选推荐】

在数字时代&#xff0c;文件泄密简直像是每个电脑用户的噩梦。 你可能还没意识到&#xff0c;重要的商业机密、个人隐私文件分分钟都可能成为他人的“囊中物”。 尤其是在公司办公或远程工作环境下&#xff0c;随便一个操作失误&#xff0c;都会导致数据流向“未知领域”。 所…

【开源免费】基于SpringBoot+Vue.JS图书馆管理系统(JAVA毕业设计)

本文项目编号 T 044 &#xff0c;文末自助获取源码 \color{red}{T044&#xff0c;文末自助获取源码} T044&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析5.4 用例设计 六、核…

C语言中易混淆概念的关键字

最快的关键字---- register register&#xff1a; 这个关键字请求编译器尽可能的将变量存在 CPU 内部寄存器中而不是通过内 存寻址访问以提高效率。注意是尽可能&#xff0c;不是绝对。你想想&#xff0c;一个 CPU 的寄存器也就那么 几个或几十个&#xff0c;你要是定义了很多很…

智能仓库|基于springBoot的智能无人仓库管理设计与实现(附项目源码+论文+数据库)

私信或留言即免费送开题报告和任务书&#xff08;可指定任意题目&#xff09; 目录 一、摘要 二、相关技术 三、系统设计 四、数据库设计 五、核心代码 六、论文参考 七、源码获取 一、摘要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xf…

《当人工智能考上名校》:拥抱变化,让自己无可替代

01 说起人工智能&#xff0c;你会想起什么呢&#xff1f; 2016年3月&#xff0c;谷歌&#xff08;Google&#xff09;旗下DeepMind公司人工智能机器人阿尔法狗&#xff08;AlphaGo&#xff09;与围棋世界冠军、职业九段棋手李世石进行围棋人机大战&#xff0c;以4比1的总比分获…

打开C嘎嘎的大门:你好,C嘎嘎!(2)

前言&#xff1a; 小编在今天已经学完了C嘎嘎的入门知识了&#xff0c;在自己敲了一遍代码以后&#xff0c;开始今天这篇代码的书写了&#xff0c;以加强我的记忆&#xff0c;下面废话不多说开始进入今天的讲解环节&#xff1a; 目录&#xff1a; 1.缺省参数 1.1.缺省参数的概…

【416】【举报垃圾信息】

这题倒挺简单的 注意一下映射关系&#xff0c;再使用字典即可。 class Solution:def reportSpam(self, message: List[str], bannedWords: List[str]) -> bool:nlen(message)if n1:return Falsedictdefaultdict(int)num0for a in message:dict[a]1for b in bannedWords:if…

NXP实战笔记(十六):NXP 32K3xx系列单片机有关OTA升级的思考

目录 1、概述 2、参考资料 3、思考点1&#xff1a;需不需要传统BootLoader&#xff1f; 3.1、无需传统BootLoader 3.2、有传统BootLoader 4、OTA升级之后是否立即实施切换 5、兼容编程会话 6、APP内部集成34、36、37服务 7、Flash放置问题 1、概述 NXP的S32K3系列单片机…

江协科技STM32学习- P16 实验-TIM输出比较(PWD驱动LED呼吸灯,舵机,直流电机)

&#x1f680;write in front&#x1f680; &#x1f50e;大家好&#xff0c;我是黄桃罐头&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流 &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd;​…

Redisson 总结

1. 基础使用 1.1 引入依赖 <dependencies><dependency><groupId>org.redisson</groupId><artifactId>redisson-spring-boot-starter</artifactId></dependency> </dependencies>包含的依赖如下 1.2 配置文件 其实默认主机就…

掌控历史:如何通过Git版本管理工具提升你的开发效率

先一览全局: git目录 一.打开git二.git bash的基础命令三.配置git四.仓库搭建五.文件操作和状态六.忽略文件七.gitee的使用1.添加公钥2.创建仓库 八.vs中使用git九.git分支常用命令十.文件差异比较十一.文件回溯和推进十二.合并冲突和消除十三.合并/压缩提交十四.远程仓库推拉十…

SkyWalking 环境搭建部署

架构简介 skywalking agent : 和业务系统绑定在一起,负责收集各种监控数据skywalking oapservice : 是负责处理监控数据的,比如接受skywalking agent的监控数据,并存储在数据库中;接受skywalking webapp的前端请求,从数据库查询数据,并返回数据给前端。Skywalking oapserv…

第一个Web项目(java+servlet+jsp)

通过百度网盘分享的文件&#xff1a;第一个Web项目 链接&#xff1a;https://pan.baidu.com/s/11vnAPeAf6Dtax7H6aYKZgA 提取码&#xff1a;1234 目录 声明&#xff1a; 简介&#xff1a; 注意&#xff1a; 操作步骤&#xff1a; 1.在idea中新建java项目&#xff0c;项目…

华为HarmonyOS地图服务 7- 在地图上绘制标记

场景介绍 本章节将向您介绍如何在地图的指定位置添加标记以标识位置、商家、建筑等。 点标记用来在地图上标记任何位置&#xff0c;例如用户位置、车辆位置、店铺位置等一切带有位置属性的事物。Map Kit提供的点标记功能&#xff08;又称 Marker&#xff09;封装了大量的触发…

TMS320F28335的定时器中断实验

TTMS320F28335 的 CPU 定时器有 3 个且均为 32 位,分别是 Timer0、Timer1、Timer2, 其中 Timer2 是为操作系统 DSP/BIOS 保留的,当未移植操作系统时,可用来做普 通的定时器。这三个定时器的中断信号分别为 TINT0,TINT1,TINT2,分别对应中断向量于 INT1,INT13,INT14。 1 …

C++速通LeetCode中等第15题-搜索二维矩阵II(两种方法)

方法一&#xff1a;二分法按行遍历查找&#xff1a; class Solution { public:bool searchMatrix(vector<vector<int>>& matrix, int target) {for (const auto& row: matrix) {auto it lower_bound(row.begin(), row.end(), target);if (it ! row.end()…

苹果macOS 15.0 Sequoia正式版发布:iPhone应用镜像玩、手机消息电脑知

9月17日苹果向 Mac 电脑用户推送了 macOS 15 更新&#xff08;内部版本号&#xff1a;24A335&#xff09;&#xff0c;除了引入数个 iOS 18 的新功能外&#xff0c;macOS 15 Sequoia 还带来了全新的 Continuity 功能 ——iPhone 镜像。 iPhone 镜像功能可以让用户直接在 Mac 上…

高密原型验证系统解决方案(上篇)

0 引言 随着当今 SoC 设计规模的快速膨胀&#xff0c;仅仅靠几 颗当代最先进的 FPGA 已经无法满足原型验证的需求。简单的增加系统的容量&#xff0c;会遇到系统时钟复位同 步&#xff0c;设计分割以及高速接口和先进 Memory控制器 IP 验证等多重困难。此时&#xff0c;一个商用…

vscode软件在 C发中常用插件

一. 简介 本文简单介绍一下&#xff0c;当做 C开发时 vscode软件常用的插件。 vscode软件是 微软公司目前提供的一款免费的开发软件&#xff0c;可以通过 vscode官网下载 vscode。 二. vscode软件在 C开发中常用插件 注意&#xff1a;vscode软件安装后&#xff0c;可以直接…