[剑指offer]面试题第[57-2]题[JAVA][和为s的连续正数序列][数学法][滑动窗口]

【问题描述】[简单]

在这里插入图片描述

【解答思路】

1. 滑动窗口

在这里插入图片描述
时间复杂度:O(N) 空间复杂度:O(1)

public int[][] findContinuousSequence(int target) {int i = 1; // 滑动窗口的左边界int j = 1; // 滑动窗口的右边界int sum = 0; // 滑动窗口中数字的和List<int[]> res = new ArrayList<>();while (i <= target / 2) {if (sum < target) {// 右边界向右移动sum += j;j++;} else if (sum > target) {// 左边界向右移动sum -= i;i++;} else {// 记录结果int[] arr = new int[j-i];for (int k = i; k < j; k++) {arr[k-i] = k;}res.add(arr);// 左边界向右移动sum -= i;i++;}}return res.toArray(new int[res.size()][]);
}
2. 数学

在这里插入图片描述

 public int[][] findContinuousSequence(int target) {int n = 2;int limit = target >> 1;LinkedList<int []> result = new LinkedList<>();while (true) {int numerator = 2 * target - n * n + n;int denominator = 2 * n;// 如果不是整除,我们需要略过。if (numerator % denominator != 0) {n++;continue;}int n1 =  numerator / denominator;// n 如果大于于中间的数,等差数列公式可以明显看到,得到的结果会大于target值; n1 不能为0,因为题目说明需要正整数;if (n >= limit || n1 <= 0) {break;}int[] a = new int[n];for (int k = n1, i = 0; i < n; i++, k++) {a[i] = k;}result.addFirst(a);n++;}return result.toArray(new int[result.size()][]);}
3.暴力
public int[][] findContinuousSequence(int target) {List<int[]> res = new ArrayList<>();if(target <= 2){return null;}for(int i = 1;i < target/2 + 1;i ++){int temp = target;int count = i;while(temp > 0){temp = temp - count;count++;}if(temp == 0){int[] arr = new int[count - i];int a = i;for(int j = 0;j < arr.length;j++){arr[j] = a;a++;}res.add(arr);}}return res.toArray(new int[0][]);}

【总结】

1.滑动窗口

在这里插入图片描述

2.数学是万能的 没有数学是万万不能的
3.细节

返回一个二重数组

List<int[]> res = new ArrayList<>();
int[] arr = new int[j-i];
return res.toArray(new int[res.size()][]);
res.add(arr);

转载链接:https://leetcode-cn.com/problems/he-wei-sde-lian-xu-zheng-shu-xu-lie-lcof/solution/shi-yao-shi-hua-dong-chuang-kou-yi-ji-ru-he-yong-h/
转载链接:https://leetcode-cn.com/problems/he-wei-sde-lian-xu-zheng-shu-xu-lie-lcof/solution/shi-qi-lai-chu-zhong-de-shu-xue-jian-dan-yi-dong-b/
参考链接:https://leetcode-cn.com/problems/he-wei-sde-lian-xu-zheng-shu-xu-lie-lcof/solution/bao-li-fa-shuang-zhi-zhen-by-sugar-31/

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

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

相关文章

[Leetcode][第112题][JAVA][路径总和][递归][队列]

【问题描述】[中等] 【解答思路】 1. 递归 时间复杂度&#xff1a;O(N) 空间复杂度&#xff1a;O(H) 从根节点开始&#xff0c;每当遇到一个节点的时候&#xff0c;从目标值里扣除节点值&#xff0c;一直到叶子节点判断目标值是不是被扣完。 class Solution {public boolean…

波动基因

突发奇想&#xff0c;会不会在癌症不同阶段中&#xff0c;同一个基因呈现出多峰的waving状态&#xff0c;这样的基因会不会在癌症阶段的转变中起着作用。 一个小想法&#xff0c;有空了做一下试试&#xff0c;现在暂时确定一下用信息熵来度量waving状态的程度。 坑越挖越多&…

[项目经验]玩转开源项目

搞懂一个开源项目的几大步骤 细看四大模块 1.首先正式开始啃开源项目之前&#xff0c;基础不可少&#xff0c;比如语言底子、网络协议、基本工具、基本应用框架、甚至包括一些设计模式等等&#xff0c;否则人家开源项目很难下牙。 2.正式看一个开源项目时&#xff0c;首先可以全…

Hihocoder #1631 : Cats and Fish 模拟

题意 现有n个鱼 m个猫 每条猫有吃一条鱼所要花去的时间 问最终x分钟后会有多少只完整的鱼 和不完整的鱼 分析 很像操作系统的资源调度的问题 这种卡时间点的问题向来都要好好把 每个步骤所发生的时间给他具体化 我们看每只猫吃一条鱼花去ci分钟 而他是在这一分钟开始的时…

49session的生命周期实例

通过超链接打开的是同一会话 定义一个page1 <% page language"java" import"java.util.*,java.text.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <me…

安卓——launchMode

网上的实在看不懂&#xff0c;在这里姑且记录下自己理解了的。 android:launchMode"" 设置Activity的启动模式 standard 每次都会启动一个新的Activity singleTop 会扫描内存栈以保证不会重复创建Activity singleTack 一样会扫描但会移除该Activity之后的全部实例…

[Leetcode]第[58]题[JAVA][最后一个单词的长度][字符串]

【问题描述】[简单] 【解答思路】 直接定位最后一个单词 先找最后一个单词最后一个字母 再找最后一个单词第一个字母 1. 常规做法 时间复杂度&#xff1a;O(N) 空间复杂度&#xff1a;O(1) class Solution {public int lengthOfLastWord(String s) {int end s.length() …

The 2014 ACM-ICPC BeiJing D - Dire Wolf HDU - 5115 区间dp

题意 n个狼 排成一排 我们要把一排狼都删除掉 删除一个狼的花费是这个狼的权值和左右两个狼的附加值 求最小花费 分析 考虑区间dp dp[i][j]表示i到j的最小花费 我们可以枚举其中的k 为序列中最后一个删除的元素 然后记忆话搜索 这样下来最深层次的元素最先删除 附加元素…

50session的销毁会话和超时管理

定义一个page1 <% page language"java" import"java.util.*,java.text.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"utf-8"&…

Navicat 连接MariaDB 失败: Host '*' is not allowed to connect to this MariaDB server

Navicat 连接MariaDB 失败&#xff1a; Host * is not allowed to connect to this MariaDB server 题描述&#xff1a;Navicat 为管理方便&#xff0c;连接Linux 中Mariadb失败&#xff0c;如下如下错误&#xff1a;Host * is not allowed to connect to this MariaDB server …

[小技巧][JAVA]判断字符串某一位是否是数字/字母

三种方法 1用JAVA自带的函数 数字 Character.isDigit(char ch) 字母 Character.isLetter(char ch) public static boolean isNumeric(String str){for (int i str.length();--i>0;){ if (!Character.isDigit(str.charAt(i))){return false;}}return true;}2用正则表达式…

[密码学基础][信息安全][每个信息安全博士生应该知道的52件事][Bristol Cryptography][第一篇]不同类型的处理器

这是每个密码学博士生应该知道的52件事系列的第一篇文章。PhD研究生在第一年结束的时候应该掌握这些问题。并且尽可能早的在他们能放弃的时候放弃(23333)无论怎样&#xff0c;我们会将这些问题在接下来的一年里表达出来&#xff0c;我自愿的为这个第一个事情的编写做出贡献。这…

android与php使用base64加密的字符串结果不一样解决方法

base64将字符串转换为字节得到同一个值 一.错误 String signString Base64.encodeToString(signContent.getBytes(),Base64.NO_WRAP); 二.正确 byte[] byteSign Base64.encode(signContent.getBytes(),Base64.NO_WRAP); String signString new String(byteSign); 大多使用ba…

CodeForces 895 B. XK Segments 二分查找

题意 定义n个数和x 让我们在这n个数中找出 多少个不同的对 分析 观察条件我们要找的是对于一个元素ai 找到另外一个元素 aj 使得a[i]<a[j] 所以我们需要排序 也就是对于每一个元素 ai 我们可以确定他后面有k个x的整数区间的范围 假设下界为lb上界为ub 那么 当a[i]除…

[密码学基础][信息安全][每个信息安全博士生应该知道的52件事][Bristol Cryptography][第11篇]DLP、CDH和DDH问题是什么?

这是一系列博客文章中最新的一篇&#xff0c;文章的主题是“做密码学每个博士生都应该知道的52件事”。这一系列问题是为了让博士生们在第一年结束时了解他们应该知道的事情。本博客是数学背景部分的第二部分&#xff0c;关注如何使用群操作设计密码原语。 就像你现在知道的那…

53pagecontext对象

建立一个test08 <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"ISO-8859-1"> <title>Insert title here&l…

51nod 1101 换零钱 简单dp

题意&#xff1a;问在现有面值金额下 输入一个m可以由多少种不同的金额组成 那么可以定义dp[i]表示i金额由多少种不同的金额组成方式 转移方程&#xff1a;dp[i] (dp[i] dp[i-cost[j])%mod&#xff1b; 首先要定义dp[0] 1&#xff1b; 然后枚举面值 看不同数目下该面值可…

[Leetcode][程序员面试金典][面试题16.11][JAVA][跳水板][数学][动态规划]

【问题描述】[简单] 【解答思路】 边界问题 k0 &#xff0c;不能产生跳水板&#xff0c;返回空数组shorter 等于longer&#xff0c;只有一种跳水板&#xff0c;返回longerk 思路 一般情况&#xff0c;k块木板&#xff0c;k种可能 跳水板的长度是 shorter(k-j)longer*j&#x…

54include对象

建立一个test11对象 <% page language"java" import"java.util.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"ISO-8859-1">…