问题描述: 在一个大小为n的数组中,其中有一个数出现的次数超过n/2,求出这个数。...这题看似很简单,但是找到最优解不容易,一般情况我们首先想到最笨的方法,每选一个数,遍历一次数组,复杂度O(N^2),或者先排序再找那个数,复杂度一般为O(NlgN),或者用hash,时间复杂度O(N),...所以这些都不是最优解,我们先分析一下这个题目,设该数出现的次数为x,则x满足,n/2+1n;所以我们可以想到如果该数和其余的数全部相抵消的话,至少还剩1个,我们从前往后遍历,设key为第一个数...,则说明key已经用完了,所以需要重新初始化key为另一个数,再重复以上步骤,因为一定有一个数大于n/2,所以遍历到最后剩下的那个数,就是要求的数。...#include #include using namespace std; /*在大小为n的数组中寻找次数超过n/2的数*/ int find_data(vector
//随机产生$num位字符串 function mkrandomstr($num=6){ $str="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ..."; $str=str_shuffle($str); return substr($str, 0,$num); } //随机产生$num位字符串 function
2024-09-07:用go语言,给定一个包含 n 个非空字符串的数组 arr,你的任务是找出一个长度为 n 的字符串数组 answer。...满足以下条件: 对于每个索引 i,answer[i] 是 arr[i] 的最短子字符串,并且这个子字符串不是 arr 中其他字符串的子字符串。 如果有多个这样的子字符串,则选择字典序最小的一个。...如果不存在这样的子字符串,则对应位置的 answer[i] 应为一个空字符串。 你需要编写一个算法来实现以上要求,并返回生成的字符串数组 answer。...解释:求解过程如下: 对于字符串 "cab" ,最短没有在其他字符串中出现过的子字符串是 "ca" 或者 "ab" ,我们选择字典序更小的子字符串,也就是 "ab" 。...对于字符串 "ad" ,不存在没有在其他字符串中出现过的子字符串。 对于字符串 "bad" ,最短没有在其他字符串中出现过的子字符串是 "ba" 。
数据结构与算法面试题:实现一个函数 fill(int[] a, int n, int v),使其将大小为 n 的数组 a 填满为 v。...简介:实现一个函数 fill(int[] a, int n, int v),使其将大小为 n 的数组 a 填满为 v。...i n; ++i) { // 循环遍历数组a的每个元素 a[i] = v; // 将当前元素赋值为v } } int main() { int a[5] = {0...}; // 声明和初始化包含5个元素的int类型数组 fill(a, 5, 5); // 调用fill函数填充数组 for (int i = 0; i 的数组...int v) { for (int i = 0; i n; ++i) { // 循环遍历数组a的每个元素 a[i] = v; // 将当前元素赋值为v
2021-08-25:给定数组father大小为N,表示一共有N个节点,father[i] = j 表示点i的父亲是点j, father表示的树一定是一棵树而不是森林,queries是二维数组,大小为M...*2,每一个长度为2的数组都表示一条查询,[4,9], 表示想查询4和9之间的最低公共祖先…,[3,7], 表示想查询3和7之间的最低公共祖先…,tree和queries里面的所有值,都一定在0~N-1...返回一个数组ans,大小为M,ans[i]表示第i条查询的答案。 福大大 答案2021-08-25: 树链剖分。 代码用golang编写。...= make([]int, this.n) this.son = make([]int, this.n) this.siz = make([]int, this.n) this.top...= make([]int, this.n) this.n-- cnum := make([]int, this.n) for i := 0; i n; i++ {
2021-07-31:给定数组father,大小为N,表示一共有N个节点,father[i] = j 表示点i的父亲是点j, father表示的树一定是一棵树而不是森林,给定数组values,大小为N,...1)让某个子树所有节点值加上v,入参:int head, int v;2)查询某个子树所有节点值的累加和,入参:int head;3)在树上从a到b的整条链上所有加上v,入参:int a, int b,...,节点编号是1~n n int // 谁是头 h int // 朴素树结构 tree [][]int // 权重数组 原始的0节点权重是6 -> val[...1] = 6 val []int // father数组一个平移,因为标号要+1 fa []int // 深度数组!...= this.son[u] { this.dfs2(v, v) } } } } // head为头的子树上,所有节点值+
昨天面试被问到这道算法题,一时没有回答上来,今天思考了一下,参阅了网上的教程,做了一个JAVA版本的实现。...方案一: 新建一个N*L的数组,将原始数组拼接存放在这个大数组中,再调用Arrays.sort()进行排序,或者使用其它排序方法即可。...,用于保存这N个数组的index,定义Node类用于保存当前数值(value)和该数字所在的数组序号(idx),并且覆写Comparetor的compare方法实现自定义排序。...思路:首先将N个数组的第一位放到PriorityQueue,循环取出优先队列的首位(最小值)放入result数组中,并且插入该首位数字所在数组的下一个数字(如果存在),直到所有数字均被加入到result...= arr.length, L; if (N == 0)//此时传入数组为空 return new int[0]; else {//判断数组是否符合规范
2024-09-25:用go语言,给定一个长度为 n 的整数数组 nums 和一个正整数 k, 定义数组的"能量"为所有和为 k 的子序列的数量之和。...请计算 nums 数组中所有子序列的能量和,并对结果取模 10^9 + 7 后返回。 输入:nums = [1,2,3], k = 3。 输出:6。...大体步骤如下: 1.定义一个数组 f 用于记录不同和值下的子序列数量,数组长度为 k+1,初始时令 f[0] = 1 表示和为 0 时只有空子序列存在。...这表示由于当前的 j 无法和当前的 x 相加得到新的和值,因此只能将和为 j 的子序列数量乘以 2。 3.最终返回 f[k],即所有和为 k 的子序列的数量之和。...总体的时间复杂度是 O(n * k),其中 n 是 nums 的长度,k 是给定的正整数。 空间复杂度为 O(k)。
2022-08-22:给定一个数组arr,长度为n,最多可以删除一个连续子数组, 求剩下的数组,严格连续递增的子数组最大长度。 n <= 10^6。 来自字节。5.6笔试。...[]; for _ in 0..n { dp.push(0); } dp[0] = 1; let mut ans = 1; // 一个数字也不删!...// // 1~rank-1 : 第二个信息的max let mut p2 = if rank0 > 1 { st.max1(rank0 - 1) + 1 }...) as usize] { cur += 1; } else { cur = 1; } // 我的当前值是rank...// 之前有没有还是rank的记录!
题目 给定一个数组,及一个长度n,生成长度为n的不重复随机数组,n不大于数组中不重复元素个数 方法一 const getRandomArr = function (arr, n) { const...result = []; while (result.length n) { // 生成随机数 const randomNum = arr[Math.floor(Math.random...) 方法二 通过map判断是否重复,降低时间复杂度 const getRandomArr2 = function (arr, n) { const result = []; const map...= new Map(); while (result.length n) { // 生成随机数 const randomNum = arr[Math.floor(Math.random...map.set(randomNum, randomNum); result.push(randomNum); } } return result; }; 复制代码 时间复杂度:O(n)
2022-04-18:things是一个N*3的二维数组,商品有N件,商品编号从1~N, 比如things[3] = [300, 2, 6], 代表第3号商品:价格300,重要度2,它是6号商品的附属商品..., 再比如things[6] = [500, 3, 0], 代表第6号商品:价格500,重要度3,它不是任何附属,它是主商品, 每件商品的收益是价格*重要度,花费就是价格, 如果一个商品是附属品,那么只有它附属的主商品购买了...,它才能被购买, 任何一个附属商品,只会有1个主商品, 任何一个主商品的附属商品数量,不会超过2件, 主商品和附属商品的层级最多有2层。...给定二维数组things、钱数money,返回整体花费不超过money的情况下,最大的收益总和。 答案2022-04-18: 本来想用rust写的,但老是编译不通过,实在没辙。...} } return n } func maxScore(things [][][]int, n, money int) int { dp := make([][]int, n)
2023-01-06:给定一个只由小写字母组成的字符串str,长度为N,给定一个只由0、1组成的数组arr,长度为N,arri等于 0 表示str中i位置的字符不许修改,arri 等于 1表示str中i...位置的字符允许修改,给定一个正数m,表示在任意允许修改的位置,可以把该位置的字符变成a~z中的任何一个,可以修改m次。...返回在最多修改m次的情况下,全是一种字符的最长子串是多长。1 N, M 所有字符都是小写。来自字节。答案2023-01-06:尝试全变成a一直到全变成z,遍历26次。...m = rand::thread_rng().gen_range(0, n) + 1; let str = random_string(n, rr); let mut arr...let mut change = 0; for l in 0..n { // l......r -> while r n {
2022-06-14:数组的最大与和。给你一个长度为 n 的整数数组 nums 和一个整数 numSlots ,满足2 * numSlots >= n 。...你需要把所有 n 个整数分到这些篮子中,且每个篮子 至多 有 2 个整数。一种分配方案的 与和 定义为每个数与它所在篮子编号的 按位与运算 结果之和。...[]; // 降低的预期! // 公主上,打一个,降低预期的值,只维持最小! let mut slack: Vec = vec!...// x,王子碰没碰过// y, 公主碰没碰过// lx,所有王子的预期// ly, 所有公主的预期// match,所有公主,之前的分配,之前的爷们!...// slack,连过,但没允许的公主,最小下降的幅度// map,报价,所有王子对公主的报价// 返回,from号王子,不降预期能不能配成!
2023-11-22:用go语言,给你一个长度为 n 下标从 0 开始的整数数组 nums。 它包含 1 到 n 的所有数字,请你返回上升四元组的数目。...大体过程如下: 算法1:countQuadruplets1 1.初始化变量:n为数组长度,ans为结果计数器,dp为动态规划数组。...b.遍历当前元素之前的所有元素(下标小于当前元素的下标),如果当前元素大于前一个元素,则将dp[j]加到ans上,并将cnt加1。...算法2:countQuadruplets2 1.初始化变量:n为数组长度,ans为结果计数器,dp为动态规划数组。 2.遍历数组,从第二个元素开始(下标为1): a.初始化计数器cnt为0。...总的时间复杂度:两种算法的时间复杂度都是O(n^2),因为需要两层循环遍历数组。 总的额外空间复杂度:两种算法的空间复杂度都是O(n),因为需要使用一个长度为n的动态规划数组dp。
2022-06-25:给定一个正数n, 表示有0~n-1号任务, 给定一个长度为n的数组time,time[i]表示i号任务做完的时间, 给定一个二维数组matrix, matrix[j] = {a,...b} 代表:a任务想要开始,依赖b任务的完成, 只要能并行的任务都可以并行,但是任何任务只有依赖的任务完成,才能开始。...返回一个长度为n的数组ans,表示每个任务完成的时间。 输入可以保证没有循环依赖。 来自美团。3.26笔试。 答案2022-06-25: 拓扑排序基础上做动态规划。 代码用rust编写。...[]; for i in 0..n { nexts.push(vec![]); } let mut in0: Vec = vec!...[]; for _ in 0..n { ans.push(0); } for i in 0..n { if in0[i as usize] ==
2022-12-22:给定一个数字n,代表数组的长度, 给定一个数字m,代表数组每个位置都可以在1~m之间选择数字, 所有长度为n的数组中,最长递增子序列长度为3的数组,叫做达标数组。...返回达标数组的数量。 1 n <= 500, 1 <= m <= 10, 500 * 10 * 10 * 10, 结果对998244353取模, 实现的时候没有取模的逻辑,因为非重点。...// f、s、t : ends数组中放置的数字!...// n : 一共的长度! // m : 每一位,都可以在1~m中随意选择数字 // 返回值:i..... 有几个合法的数组!...// 尤其是理解ends数组的意义! fn number2(n: i32, m: i32) -> i32 { //repeat(vec!
2022-09-09:给定一个正整数 n,返回 连续正整数满足所有数字之和为 n 的组数 。...k + 1),这个式子来说,只要给定不同的一组x和k,就对应一种不同的方案 进一步分析可以看出: 如果k为偶数,那么2x + k + 1就是奇数 如果k为奇数,那么2x + k + 1就是偶数 2N...= 左 K 右 2x + k + 1 2N 奇数因子K, 2x + k + 1 也就是说,对于每一种方案,k和2x + k + 1,一定是不同的,并且连奇偶性都相反 所以2N里任何一个奇数因子,可能作为...= 1表示已经找到了所有奇数因子 // N !...= 1表示只残留着最后一个奇数因子了 // 简单证明:如果N最后残留着不只一个奇数因子, // 比如x*y(不妨设xN //
2022-12-22:给定一个数字n,代表数组的长度,给定一个数字m,代表数组每个位置都可以在1~m之间选择数字,所有长度为n的数组中,最长递增子序列长度为3的数组,叫做达标数组。返回达标数组的数量。...1 n 的时候没有取模的逻辑,因为非重点。来自微众银行。...// f、s、t : ends数组中放置的数字!...// n : 一共的长度!// m : 每一位,都可以在1~m中随意选择数字// 返回值:i..... 有几个合法的数组!...// 尤其是理解ends数组的意义!fn number2(n: i32, m: i32) -> i32 { //repeat(vec!
2024-12-14:K 周期字符串需要的最少操作次数。用go语言,给定一个长度为n的字符串 word 和一个整数k,k是n的因数。...每次操作可以选择两个下标i和j,使得i和j都可以被k整除,然后用从j开始的长度为k的子串替换从i开始的长度为k的子串。要使得word成为一个K周期字符串,需要进行最少的操作次数。...一个K周期字符串是指存在一个长度为k的字符串s,通过多次连接s可以得到word。比如,如果word == "ababab",那么当s = "ab"时,word是一个2周期字符串。...大体步骤如下: 1.初始化变量 n 为字符串 word 的长度,并设定变量 res 初始值为最大整数。 2.创建一个空的计数映射 count,用于存储不同子串的出现次数。...总体额外空间复杂度: • 需要额外的空间来存储计数映射 count,其大小取决于字符串中包含 unique 子串的数量,最坏情况下可达到 O(n/k)。
领取专属 10元无门槛券
手把手带您无忧上云