LeetCode1237找出给定方程的正整数解
题目
给定方程f和值z,找出给定方程f(x,y)=z的正整数解x,y。f(x,y)关于x、y都是严格单调的。
题目保证 f(x, y) == z 的解处于 1 <= x, y <= 1000 的范围内。
方案
暴力双层循环O(N*N)
暴力,双层循环遍历,由于f是单调的,所以一旦遇到大于,则break。同样遇到等于,也可以加入结果并break。时间复杂度O(N*N),N是最大值1000.
public List<List<Integer>> findSolution(CustomFunction customfunction, int z) {
List<List<Integer>> res=new ArrayList<>();
int MAX_VAL=1000;
for (int i = 1; i <=MAX_VAL ; i++) {
for (int j = 1; j <= MAX_VAL; j++) {
int cul=customfunction.f(i,j);
if(cul==z){
List<Integer> list=new ArrayList<>(2);
list.add(i);
list.add(j);
res.add(list);
break;
}else if(cul>z){
break;
}
}
}
return res;
}
单层循环+二分搜索O(NlogN)
可以一层for+一个二分搜索
由于已知x,y的范围,并且函数单调,则可以用二分。对每个x,尝试二分查找对应的y。O(NlogN)
public List<List<Integer>> findSolution(CustomFunction customfunction, int z) {
List<List<Integer>> res = new ArrayList<>();
int MAX_VAL = 1000;
for (int i = 1; i <= MAX_VAL; i++) {
int j = binarySearch(1, MAX_VAL, customfunction, z, i);
if (j != -1) {
List<Integer> list = new ArrayList<>(2);
list.add(i);
list.add(j);
res.add(list);
}
}
return res;
}
private int binarySearch(int start, int end, CustomFunction customfunction, int z, int i) {
int left = start;
int right = end;
while (left <= right) {
int mid = (left + right) / 2;
int tmpres = customfunction.f(i, mid);
if (tmpres == z) {
return mid;
} else if (tmpres < z) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1;
}
双指针O(N)
可以用双指针。
类似矩阵的方法:
从左下角或者右上角找。选择从左下角找,如果f(x,y)<z,则要走向更大值,需要y++想右;如果大于,则需要向上(x--).如果等于,就需要两个方向都要尝试,往任意一个方向都可以。
public List<List<Integer>> findSolution(CustomFunction customfunction, int z) {
List<List<Integer>> res = new ArrayList<>();
int x=1000,y=1;
while(x>=1&&y<=1000){
int tmp=customfunction.f(x,y);
if(tmp<z){
y++;
}else if(tmp>z){
x--;
}else{
List<Integer> list = new ArrayList<>(2);
list.add(x);
list.add(y);
res.add(list);
x--;
}
}
return res;
}
为什么往任意一个方向都可以而不会漏掉?可以类比到矩阵中,如果出现等于,
12345
23456
找f(x,y)=4的,如果从左下角开始,找到第一个4,方案1向上、向右能到第二个4;方案2向右、向上到第二个4.所以当相等的时候,无论向哪个方向都能走到所有的目标值而不会漏掉,因为等会还是会根据单调性向另一个方向走。
LeetCode1237找出给定方程的正整数解的更多相关文章
- leetcode-160场周赛-5238-找出给定方程的正整数解
题目描述: class Solution: def findSolution(self, customfunction: 'CustomFunction', z: int) -> List[Li ...
- Leetcode33--->Search in Rotated Sorted Array(在旋转数组中找出给定的target值的位置)
题目: 给定一个旋转数组,但是你不知道旋转位置,在旋转数组中找出给定target值出现的位置:你可以假设在数组中没有重复值出现 举例: (i.e., 0 1 2 4 5 6 7 might becom ...
- [NBUT 1224 Happiness Hotel 佩尔方程最小正整数解]连分数法解Pell方程
题意:求方程x2-Dy2=1的最小正整数解 思路:用连分数法解佩尔方程,关键是找出√d的连分数表示的循环节.具体过程参见:http://m.blog.csdn.net/blog/wh2124335/8 ...
- 在排序数组中查找元素的第一个和最后一个位置(给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。)
示例 1: 输入: nums = [5,7,7,8,8,10], target = 8 输出: [3,4] 示例 2: 输入: nums = [5,7,7,8,8,10], target = 6 输出 ...
- JAVA冒泡排序/JAVA冒泡排序再找出给定数据中的最大值最小值/JAVA数组排序
//数组中排序 int in[] = {1,6,5,8,9}; Arrays.sort(in); for(int i=0;i<in.length;i++){ Sys ...
- 2019年春季学期第二周作业 基础作业 请在第一周作业的基础上,继续完成:找出给定的文件中数组的最大值及其对应的最小下标(下标从0开始)。并将最大值和对应的最小下标数值写入文件。 输入: 请建立以自己英文名字命名的txt文件,并输入数组元素数值,元素值之间用逗号分隔。 输出 在不删除原有文件内容的情况下,将最大值和对应的最小下标数值写入文件
~~~ include<stdio.h> include<stdlib.h> int main() { FILE*fp; int i=0,max=0,j=0,maxb=0; i ...
- Leetcode34--->Search for a Range(在排序数组中找出给定值出现的范围)
题目:给定一个排序数组,找出给定的target值出现的范围:算法复杂度要求在O(logn);如果没有找到,则返回[-1, -1]; 举例: For example,Given [5, 7, 7, 8, ...
- 给定a、b两个文件,各存放50亿个url,每个url各占用64字节,内存限制是4G,如何找出a、b文件共同的url?
给定a.b两个文件,各存放50亿个url,每个url各占用64字节,内存限制是4G,如何找出a.b文件共同的url? 可以估计每个文件的大小为5G*64=300G,远大于4G.所以不可能将其完全加载到 ...
- 用JAVA写一个函数,功能例如以下: 随意给定一组数, 找出随意数相加之后的结果为35(随意设定)的情况
用JAVA写一个函数.功能例如以下:随意给定一组数,比如{12,60,-8,99,15,35,17,18},找出随意数相加之后的结果为35(随意设定)的情况. 能够递归算法来解: package te ...
随机推荐
- 变量、内存区域、MDK文件(map、htm)
变量分为:局部变量和全局变量 局部变量:函数体内部定义的变量,作用域为函数内部,static声明(静态局部变量)该变量则函数调用结束后不消失而保留值,分配的存储空间不释放. 全局变量:函数体外部定义的 ...
- Mac下source tree 下的安装
安装时出现了以下错误,解决方法 git -c diff.mnemonicprefix=false -c core.quotepath=false -c credential.helper=source ...
- 03 Windows安装Java环境
Java环境安装 使用微信扫码关注微信公众号,并回复:"Java环境",免费获取下载链接! 1.卸载(电脑未装此程序,跳过此过程) 找到电脑上面的控制面板 找到这两个文 ...
- mysql-centos8下安装
参考文章 1.下载安装包 客服端与服务端 依赖包 2.linux下检查是否安装 rpm -qa | grep -i mysql 安装过会显示软件名称,没安装过就是空的 3.安装包传到虚拟机 先需要把安 ...
- 顺序栈(C++)
栈的定义为只允许在表的末端进行插入和删除的线性表.简而言之就是先进后出的线性表. 插入和删除的一端被称呼为栈顶(top),而不允许插入删除的一端被称为栈底(bottom).无元素时的栈即为空栈. 使用 ...
- Objective-C运行时定义了几种重要的类型
Objective-C运行时定义了几种重要的类型. Class:定义Objective-C类 Ivar:定义对象的实例变量,包括类型和名字. Protocol:定义正式协议. objc_propert ...
- 实现new Date(), 获取当前时间戳
JS 获取时间戳: 我相信大家找了很久了吧! 希望我写的这个对您有些帮助哦~ 大家是不是以为时间戳是关于时间的,都去 new Date() 里面找方法了啊,我来告诉你们正确的吧 其实大家用 JS 里的 ...
- 【Matlab】CFAR/phased.CFARDetector2D
| CFAR学习进行时ing... | CFAR原理.参数 检测阈值\(T = αP_n\) \(P_n\)是噪声功率估计,\(α\)是比例因子 训练单元:训练噪声,估计\(P_n = \frac{1 ...
- 【HarmonyOS】【xml】初学XML布局作业
首先要明确,有两种布局方式 线性布局:DirectionalLayout 依赖布局:DependentLayout 好,接下来看一看下面的例子 页面案例1 代码如下: <?xml version ...
- 数据挖掘实战 - 天池新人赛o2o优惠券使用预测
数据挖掘实战 - o2o优惠券使用预测 一.前言 大家好,家人们.今天是2021/12/14号.上次更新是2021/08/29.上篇文章中说到要开两个专题,果不其然我鸽了,这一鸽就是三个多月.今天,我 ...