不重复打印排序数组中相加和为给定值的所有二元组和三元组

本文主要是介绍不重复打印排序数组中相加和为给定值的所有二元组和三元组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

//不重复打印排序数组中相加和为给定值的所有二元组和三元组
public class GetArrNum{//(1)获得排序数组中为给定值的二元组public static void GetArrNum2(int []arr,int k){if(arr==null||k<arr[0]||arr.length<2){return;}//设置两个指针int i=0;int j=arr.length-1;for(int w=0;w<arr.length;w++){if((arr[i]+arr[j]==k)&&(i!=j)){System.out.println(arr[i]+" "+arr[j]);j--;}else if(arr[i]+arr[j]>k){break;}else{i++;}	}System.out.println();}//(2)获得排序数组中为给定值的三元祖public static void GetArrNum3(int[]arr,int k){ if(arr==null||k<arr[0]||arr.length<3){return;}//设置两个指针int i=0;while(i!=arr.length-3){for(int j=arr.length-1;j>=3;j--){for(int w=i+1;w<arr.length-1;w++){if(arr[i]+arr[j]+arr[w]==k&&((w<j))&&(i<j)){System.out.println(arr[i]+" "+arr[w]+" "+arr[j]);}else if(arr[i]+arr[j]+arr[w]>k){break;}}}i++;}System.out.println();}//(2)获得排序数组中为给定值的三元祖 方法二O(N*N)public static void GetArrNum3T(int[] arr, int k) {if (arr == null || arr.length < 3) {return;}for (int i = 0; i < arr.length - 2; i++) {if (i == 0 || arr[i] != arr[i - 1]) {printRest(arr, i, i + 1, arr.length - 1, k - arr[i]);}}}public static void printRest(int[] arr, int f, int l, int r, int k) {while (l < r) {if (arr[l] + arr[r] < k) {l++;} else if (arr[l] + arr[r] > k) {r--;} else {if (l == f + 1 || arr[l - 1] != arr[l]) {System.out.println(arr[f] + "," + arr[l] + "," + arr[r]);}l++;r--;}}}public static void main(String[]args){int[]arr={-8,-4,-3,0,1,2,4,5,8,9};int k=10;GetArrNum2(arr,k);GetArrNum3(arr,k);GetArrNum3T(arr,k);}
}


这篇关于不重复打印排序数组中相加和为给定值的所有二元组和三元组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1082471

相关文章

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

Python中lambda排序的六种方法

《Python中lambda排序的六种方法》本文主要介绍了Python中使用lambda函数进行排序的六种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1.对单个变量进行排序2. 对多个变量进行排序3. 降序排列4. 单独降序1.对单个变量进行排序

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE