Java找出数字组合的方法是什么
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这篇文章主要介绍"Java找出数字组合的方法是什么",在日常操作中,相信很多人在Java找出数字组合的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Java找
千家信息网最后更新 2025年12月03日Java找出数字组合的方法是什么
这篇文章主要介绍"Java找出数字组合的方法是什么",在日常操作中,相信很多人在Java找出数字组合的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Java找出数字组合的方法是什么"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
给出一组候选数字(C)和目标数字(T),找到C中所有的组合,使找出的数字和为T。C中的数字可以无限制重复被选取。例如,给出候选数组[2,3,6,7]和目标数字7所求的解为:[7] 和 [2,2,3]给定一个数组,从中找出一组数来,使其和等于target。数组无序,但都是正整数。与40题比较I和II不同的是,I数组里没有重复的数,但一个数可以用多次;II数组里有重复,一个数只能用一次。I和II都要求返回结果中没有重复的解,且每个解中的数都按非递减排好序。
package com.lifeibigdata.algorithms.leetcode;import java.util.ArrayList;import java.util.Arrays;import java.util.List;/** * Created by lifei on 16/7/4. */public class CombinationSum { public static void main(String[] args) { int[] can = new int[]{5,3,2,1}; CombinationSum cs = new CombinationSum(); cs.combinationSum(can,6); for (List list:ans) { for (int i:list) { System.out.print(i+","); } System.out.println(); } }// static List> result;// List solu;// public List> combinationSum(int[] candidates, int target) {// result = new ArrayList<>();// solu = new ArrayList<>();// Arrays.sort(candidates);// getCombination(candidates, target, 0, 0);// return result;// }// public void getCombination(int[] candidates, int target, int sum, int level){// if(sum>target) return;// if(sum==target){// result.add(new ArrayList<>(solu));// return;// }// for(int i=level;i> ans = new ArrayList>();//声明全局变量 int[] cans = {}; public List> combinationSum(int[] candidates, int target) { this.cans = candidates; Arrays.sort(cans); backTracking(new ArrayList(), 0, target); return ans; } public void backTracking(List cur, int from, int target) {//初次cur为空 if (target == 0) { List list = new ArrayList(cur); ans.add(list); } else { for (int i = from; i < cans.length && cans[i] <= target; i++) {//界限条件 cur.add(cans[i]); backTracking(cur, i, target - cans[i]); //递归调用 cur.remove(new Integer(cans[i])); } } } /** * * * * 1,1,1,1,1,1, 1,1,1,1,2, 1,1,1,3, 1,1,2,2, 1,2,3, 1,5, 2,2,2, 3,3, */}
到此,关于"Java找出数字组合的方法是什么"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
数字
方法
组合
数组
学习
个数
更多
目标
帮助
不同
实用
接下来
从中
全局
变量
所求
整数
文章
无限制
条件
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
行业软件开发哪家比较好
软件开发哪家最好用
分布式集群和数据库的区别
网络安全的语言有哪些
组态王显数据库控件
软件开发纠纷代理词
两台服务器每台电脑只能访问一台
数据库查询含有字母
软件开发人员组合
肖子彤网络安全
梦幻手游画龙点睛服务器
大数据应用服务器异常
惟望软件开发
项目管理软件开发ppt模板
怎样停止优化应用数据库
全球地理数据库分享
广西企业软件开发哪家好
宿迁什么是网络技术
数据库测试皮肤颜色
青岛达内软件开发
怀旧服服务器中英文对照
深圳市ai服务器
数据库查询相关怎么弄
前海全融互联网科技
四川大学网络安全学科评估
数据库技术测验
惊无命是哪个服务器的
人大教育基础数据库
数据库怎么判断是第几范式视频
软件开发阶段需求分析