【牛客周赛Round 27】题目讲解

news2025/1/30 16:43:49

题目一  小红的二进制删数字:

        小红拿到了一个二进制字符串 s,她可以删掉其中的一些字符,使得最终该字符串为一个2的幂(即可以表示为 2^k 形式的数)。小红想知道,自己最少删几个字符可以达成?请你编写一个函数返回这个答案。

具体思路:

       看到这道题目,我们要联想一个2次幂的整数在二进制中是如何表示的,在整个二进制字符串中只有1个数是1,其余的数字全是0,这样一个数是一个2次幂的整数。

       所以题意就变成了我要消去字符串中多余的1,使得整个二进制字符串中只含有一个1,这样就符合题意了。我们先统计所有的1的个数,再减去1就是答案。

代码:

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param s string字符串 
     * @return int整型
     */
    int minCnt(string s) {
        // write code here
        int n = s.size();
        int cnt = 0;
        for(int i = 0; i < n; i++)
        {
            if(s[i] == '1') cnt++;
        }
        return cnt - 1;
    }
};

应该注意的地方:

       当题目中出现2次幂的字眼时,我们应该往二进制的方向去想。


题目二  嘤嘤的新平衡树:

       给定一棵二叉树,二叉树的每个结点只有0或2个孩子。你需要对每个结点赋值一个正整数,使得每个结点的左右子树权值和相等。你需要返回所有结点的最小权值和对 10^9+7 取模的结果。二叉树结点个数不超过10^5。

具体思路:

       这道题目要求的是所有结点的权值和最小,题目中又没有限制根节点的权值必须是子节点的权值和,所以这道题目,我首先想到的是每一个节点的权值都是1,这样就是最小的权值和。但是又这种情况:这个二叉树不是完全二叉树。

       这样又要求左右子树的权值和相同,我们只要将这个树抽象为完全二叉树,但是并不是真的二叉树,只是权值和满足完全二叉树。类似于下图的情况:

       所以,这道题目的思路是先算出整个二叉树的最大深度,然后进行倍增计算。 

代码:

/**
 * struct TreeNode {
 *	int val;
 *	struct TreeNode *left;
 *	struct TreeNode *right;
 *	TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param tree TreeNode类 
     * @return int整型
     */
    
    int dfs(TreeNode* tree)
    {
        if(tree == NULL)
            return 0;
        int len = max(dfs(tree->left), dfs(tree->right)) + 1;
        return len;
    }
    
    int getTreeSum(TreeNode* tree) {
        // write code here
        
        int ans = 1;
        int len = dfs(tree);
        int mod = 1e9 + 7;
        for(int i = 0; i < len; i++)
        {
            ans = ans * 2 % mod;
        }
        return ans - 1;
    }
};

应该注意的地方:

       注意最后答案要减一,等比公式告诉我们要减一hhh。基本树的题目要往递归的方向去思考。


 题目三  连续子数组数量:

       给定一个数组,请你编写一个函数,返回元素乘积末尾零数量大于等于x的连续子数组数量。答案可能太大,请将答案对10^9+7取模再返回。 数组长度不超过10^5。数组元素、x均为不超过10^9的正整数。

具体思路:

       这个就是将每一个的数对于2和5的因子是多少,然后利用双指针建立滑动窗口来计算有多少个方案。先让左右指针都指向0,然后让右指针先走,如果满足2或5的因子个数的最小值大于等于x的话,就说明满足题意不管后面数组中的数字是几,都满足题意,直接用n-r来计算,同时,我们可以左移左指针,来缩小数组长度看是否满足题意。

代码:

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param a int整型vector 
     * @param x int整型 
     * @return int整型
     */
    int getSubarrayNum(vector<int>& a, int x) {
        // write code here
        int n = a.size();
        vector<int> c2(n), c5(n);
        for(int i = 0; i < n; i++)
        {
            int x = a[i];
            while (x % 2 == 0)
            {
                c2[i]++;
                x /= 2;
            }
            while (x % 5 == 0)
            {
                c5[i]++;
                x /= 5;
            }
        }
        int res = 0;
        int l = 0;
        int cnt2 = 0, cnt5 = 0;
        int mod = 1e9 + 7;
        for(int r = 0; r < n; r++)
        {
            cnt2 += c2[r];
            cnt5 += c5[r];
            while (min(cnt2, cnt5) >= x)
            {
                res = (res + n - r) % mod;
                cnt2 -= c2[l];
                cnt5 -= c5[l];
                l++;
            }
        }
        return res;
    }
};

应该注意的地方:

       这道题目还是要多想一想。


题目四  好矩阵:

我们定义一个矩阵为“好矩阵”,当且仅当该矩阵所有2*2的子矩阵数字和为偶数。

例如:

是好矩阵,两个2*2的子矩阵的和分别是8和12。请问n行m列,矩阵中每个数均在[1,x]范围内的好矩阵有多少种?由于答案过大,请对10^9+7取模。数据范围:2≤n,m,x≤10^9 保证x为偶数。

具体思路:

       看到数据范围很大,说明不是用一般的循环来实现算法的,而是需要我们利用这个数学公式来实现算法的,这道题目就是一个典型的组合数学。

       2x2格子总合是偶数,其实主要关注0-1奇偶就行,不需要关注其具体是什么值。在这个基础上,我们可以找到如下规律:就是第一行,每个位子可以随意选择,即0-1奇偶都行,然后从第二行开始,除了第一列,可以0-1奇偶选择,其他列的值都是固定的,因此其总方案数为: 2^m * 2^(n - 1) == 2^(n+m-1)

       然后我们在回过来头考虑在[1,x]具体的选择值。由于x为偶数,所以根据乘法原理,其附带选择数位 (x/2)^(m*n)。最终的结果为: 2^(n+m-1) * (x/2)^(m*n)。利用快速幂可以进行求解。

代码:

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param n int整型 
     * @param m int整型 
     * @param x int整型 
     * @return int整型
     */
    int mod = 1e9 + 7;
    
    long long quickpow(long long a, long long b)
    {
        long long res = 1;
        while (b)
        {
            if(b & 1) res = res * a % mod;
            a = a * a % mod;
            b >>= 1;
        }
        return res % mod;
    }
    
    int numsOfGoodMatrix(int n, int m, int x) {
        // write code here
        int res = 0;
        res = quickpow(2, m + n - 1) * quickpow(x / 2, 1ll * m * n) % mod;
        return res;
    }
};

应该注意的地方:

       一看到数据范围比较大,就要往数学的方向来看。

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

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

相关文章

哈希表的实现(2):拉链法实现哈希表

一&#xff0c;拉链法 在使用线性探测法实现哈希表时&#xff0c;会发生哈希冲突。这个时候就得向后找位置给新插入的值。这个过程无疑会对哈希表的效率有很大的影响。那我们能不能通过另一种方式来实现哈希表&#xff0c;让哈希表不会发生哈希冲突呢&#xff1f;答案当然是可以…

海外媒体宣发:新闻媒体发稿引爆社交媒体的7个诀窍-华媒舍

社交媒体的崛起已经改变了新闻媒体的传播方式。从Facebook到Twitter&#xff0c;从Instagram到LinkedIn&#xff0c;社交媒体平台为新闻媒体提供了一个巨大且潜力无限的受众群体。要在这个竞争激烈的环境中引爆社交媒体&#xff0c;需要一些技巧和诀窍。在本篇文章中&#xff0…

代码随想录算法训练营day8|344.反转字符串、541.反转字符串II、54.替换数字、151.翻转字符串里的单词、55.右旋转字符串

344.反转字符串 541. 反转字符串II 卡码网&#xff1a;54.替换数字 151.翻转字符串里的单词 卡码网&#xff1a;55.右旋转字符串 344.反转字符串 建议&#xff1a; 本题是字符串基础题目&#xff0c;就是考察 reverse 函数的实现&#xff0c;同时也明确一下 平时刷题什么时候用…

2624. 蜗牛排序

说在前面 &#x1f388;不知道大家对于算法的学习是一个怎样的心态呢&#xff1f;为了面试还是因为兴趣&#xff1f;不管是出于什么原因&#xff0c;算法学习需要持续保持。 题目描述 请你编写一段代码为所有数组实现 snail(rowsCount&#xff0c;colsCount) 方法&#xff0c;…

第 4 章 链表

文章目录 4.1 链表(Linked List)介绍4.2 单链表的应用实例4.3 单链表面试题(新浪、百度、腾讯)4.4 双向链表应用实例4.4.1 双向链表的操作分析和实现4.4.2 课堂作业和思路提示 4.5 单向环形链表应用场景4.6 单向环形链表介绍4.7 Josephu 问题4.8 Josephu 问题的代码实现 4.1 链…

Fiddler工具 — 14.Composer界面

1、Composer介绍 Fiddler的Composer的功能就是用来创建HTTP Request然后发送请求。 允许自定义请求发送到服务器&#xff0c;即可以手动创建一个新的请求&#xff0c;也可在会话表中拖拽一个现有的请求。 Fiddler创建Request有两种方式&#xff1a; 可以手写一个Request。 在…

如何在 openKylin 上安装 ONLYOFFICE 文档?

文章作者&#xff1a;ajun ONLYOFFICE 文档是一款全面的在线办公工具&#xff0c;提供了文本文档、电子表格和演示文稿的查看和编辑功能。它高度兼容微软 Office 格式&#xff0c;包括 .docx、.xlsx 和 .pptx 等文件格式&#xff0c;并支持实时协作编辑&#xff0c;使团队成员能…

DHCP自动获取实验和DNS正向解析实验

一、服务程序 1.1DHCP定义 DHCP&#xff08;动态主机配置协议&#xff09;是一个局域网的网络协议。指的是由服务器控制一段IP地址范围&#xff0c;客户机登录服务器时就可以自动获得服务器分配的IP地址和子网掩码。默认情况下&#xff0c;DHCP作为Windows Server的一个服务组…

嵌入式软件开发对硬件知识的掌握要求要多高?

嵌入式软件开发对硬件知识的掌握要求要多高&#xff1f; 在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「嵌入式的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff0…

QT+jenkins window环境实现一键自动化构建打包签名发布

jenkins + QT 自动化构建打包 1.官网下载地址: Jenkins download and deployment,下载最新版本的安装包并安装。安装过程中,会要求你输入端口号并记住。 2.java下载地址:Java Downloads | Oracle,下载最新版本的安装包并安装。 3.浏览器输入网址:127.0.0.1: port, port为…

【Docker】镜像的构建与上传下载阿里云

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《Docker实战》。&#x1f3af;&#x1f3af; &…

STEGNN

STEGNN 摘要 随着智能交通系统(ITS)逐渐融入我们的日常生活,人们普遍认为路网预测是智能交通系统的杀手锏,具有很高的社会和经济效益。然而,目前的解决方案忽视了时空交通数据的异质性,无法捕捉隐藏的时空相关性。本文介绍了 STEGNN:一种用于路网预测的新型时空嵌入图神…

linux主机的免密登录

实现linux主机之间的相互免密登录 在进行远程登录的时&#xff0c;服务器和主机间进行认证阶段分为&#xff1a; 基于口令认证&#xff08;不安全&#xff0c;易被抓包拦截获取&#xff09; 客户机连接服务器时&#xff0c;服务器将自己的公钥返回给客户机 客户机会将服务器的…

vue知识-04

计算属性computed 注意&#xff1a; 1、计算属性是基于它们的依赖进行缓存的 2、计算属性只有在它的相关依赖发生改变时才会重新求值 3、计算属性就像Python中的property&#xff0c;可以把方法/函数伪装成属性 4、computed: { ... } 5、计算属性必须要有…

视频号小店发展前景怎样?适合新手入驻吗?

我是电商珠珠 视频号于22年7月发展了属于自己的平台-视频号小店。作为一个发展了才一年的平台来说&#xff0c;很多人都不敢入驻&#xff0c;害怕它很快就会垮掉。 我们团队在22年10月的时候&#xff0c;开始入驻其中。发现它的玩法和抖音小店相比并没有什么两样。 在刚开始…

深度学习工具-如何选择服务器和GPU

深度学习训练通常需要大量的计算。目前&#xff0c;GPU是深度学习最具成本效益的硬件加速器。与CPU相比&#xff0c;GPU更便宜&#xff0c;性能更高&#xff0c;通常超过一个数量级。此外&#xff0c;一台服务器可以支持多个GPU&#xff0c;高端服务器最多支持8个GPU。更典型的…

【GitHub项目推荐--6 个 Github 项目学习 Spring Boot】【转载】

一切都在证明&#xff0c;Spring Boot 已经成为了 Java 程序员必备的技能。并且可以预见的是未来 Spring Boot 的发展还会更好。学习一门技术最好的方式就是理论 实践&#xff0c;学习网理论基础&#xff0c;直接上 Demo 。跑通 Demo &#xff0c;在探究原理。如果用的非常熟练…

06-微服务OpenFeigh和Sentinel持久化

一、OpenFeign基础应用 1.1 概念 OpenFeign是一种声明式、模板化的HTTP客户端。在Spring Cloud中使用OpenFeign&#xff0c;可以做到使用HTTP请求访问远程服务&#xff0c;就像调用本地方法一样的&#xff0c;开发者完全感知不到这是在调用远程方法&#xff0c;更感知不到在访…

第 2 章 数据结构和算法概述

文章目录 2.1 数据结构和算法的关系2.2 看几个实际编程中遇到的问题2.2.1 问题一-字符串替换问题2.2.2 一个五子棋程序2.2.3 约瑟夫(Josephu)问题(丢手帕问题)2.2.4 其它常见算法问题: 2.3 线性结构和非线性结构2.3.1 线性结构2.3.2 非线性结构 2.1 数据结构和算法的关系 数据 …

利用gulp工具对常规web项目进行压缩打包

前言 对于一个常规的web项目&#xff0c;如下项目目录 |- imgs | - img1.png | - img2.png |- js | - user.js | - utils.js |- css | - index.css | - user.css |- html | - user.html |- index.html可以使用各种构建工具&#xff08;如webpack、gulp、grunt等&#xff09;来…