当前位置: 首页 > news >正文

英文网站编辑怎么做镇江科技有限公司

英文网站编辑怎么做,镇江科技有限公司,广州淘宝运营培训,营销网站域名设计JAVA代码编写 216. 组合总和III 找出所有相加之和为 n 的 k 个数的组合,且满足下列条件: 只使用数字1到9每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。 示例 1: 输入: k …

JAVA代码编写

216. 组合总和III

  • 找出所有相加之和为 nk 个数的组合,且满足下列条件:

    • 只使用数字1到9
    • 每个数字 最多使用一次

    返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

    示例 1:

    输入: k = 3, n = 7
    输出: [[1,2,4]]
    解释:
    1 + 2 + 4 = 7
    没有其他符合的组合了。
    

    示例 2:

    输入: k = 3, n = 9
    输出: [[1,2,6], [1,3,5], [2,3,4]]
    解释:
    1 + 2 + 6 = 9
    1 + 3 + 5 = 9
    2 + 3 + 4 = 9
    没有其他符合的组合了。
    

    示例 3:

    输入: k = 4, n = 1
    输出: []
    解释: 不存在有效的组合。
    在[1,9]范围内使用4个不同的数字,我们可以得到的最小和是1+2+3+4 = 10,因为10 > 1,没有有效的组合。
    

    提示:

    • 2 <= k <= 9
    • 1 <= n <= 60

教程:https://programmercarl.com/0216.%E7%BB%84%E5%90%88%E6%80%BB%E5%92%8CIII.html#%E5%85%B6%E4%BB%96%E8%AF%AD%E8%A8%80%E7%89%88%E6%9C%AC

方法一:回溯

思路

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();public List<List<Integer>> combinationSum3(int k, int n) {backTracking(n, k, 1, 0);return result;}private void backTracking(int targetSum, int k, int startIndex, int sum) {// 减枝if (sum > targetSum) {return;}if (path.size() == k) {if (sum == targetSum) result.add(new ArrayList<>(path));return;}// 减枝 9 - (k - path.size()) + 1for (int i = startIndex; i <= 9 - (k - path.size()) + 1; i++) {path.add(i);sum += i;backTracking(targetSum, k, i + 1, sum);//回溯path.removeLast();//回溯sum -= i;}}
}

17.电话号码的字母组合

    • 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。

      给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

      img

      示例 1:

      输入:digits = "23"
      输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]
      

      示例 2:

      输入:digits = ""
      输出:[]
      

      示例 3:

      输入:digits = "2"
      输出:["a","b","c"]
      

      提示:

      • 0 <= digits.length <= 4
      • digits[i] 是范围 ['2', '9'] 的一个数字。

教程:https://programmercarl.com/0017.%E7%94%B5%E8%AF%9D%E5%8F%B7%E7%A0%81%E7%9A%84%E5%AD%97%E6%AF%8D%E7%BB%84%E5%90%88.html

方法一:回溯

思路

class Solution {//设置全局列表存储最后的结果List<String> list = new ArrayList<>();public List<String> letterCombinations(String digits) {if (digits == null || digits.length() == 0) {return list;}//初始对应所有的数字,为了直接对应2-9,新增了两个无效的字符串""String[] numString = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};//迭代处理backTracking(digits, numString, 0);return list;}//每次迭代获取一个字符串,所以会设计大量的字符串拼接,所以这里选择更为高效的 StringBuildStringBuilder temp = new StringBuilder();//比如digits如果为"23",num 为0,则str表示2对应的 abcpublic void backTracking(String digits, String[] numString, int num) {//遍历全部一次记录一次得到的字符串if (num == digits.length()) {list.add(temp.toString());return;}//str 表示当前num对应的字符串String str = numString[digits.charAt(num) - '0'];for (int i = 0; i < str.length(); i++) {temp.append(str.charAt(i));//cbackTracking(digits, numString, num + 1);//剔除末尾的继续尝试temp.deleteCharAt(temp.length() - 1);}}
}
http://www.yayakq.cn/news/86288/

相关文章:

  • 广东备案网站邯郸网站建设市场
  • 网站构建计划可以用电脑做网站主机吗
  • 土巴兔这种网站怎么做php手机网站开发
  • 说明设计网站开发方案流程深圳软件公司招聘
  • 做视频的模板下载网站泉州做网站联系方式
  • 福鼎市城市建设监察大队网站浙江百度推广开户
  • 网站建设注意哪些内容怎样建一个个人网站
  • 大连权威发布网站百度首页关键词优化
  • 做淘宝网站的主机怎么用支付宝做发卡网站
  • 网站建设服务哪家好欢迎进入河南国安建设集团有限公司网站
  • 站长工具高清有吗有什么做分销的几个网站
  • 网站建设中 html5 模板cms网站制作
  • 做门户网站需要什么资质那个网站做字体
  • 上海网站设计工作室深圳哪里做网站
  • 新吴区推荐做网站公司自助建站的软件
  • 无锡专业做网站的免费域名注册 国外
  • 西安企业网站制作柳州 网站开发
  • wordpress 自定义字段调用百度seo原理
  • 江苏网站设计方案苏州网站备案查询
  • 网站建设服务收费网络推广优化网站
  • 网站建设初期怎么添加内容推荐好的设计网站
  • 虚拟币网站开发国家备案查询
  • 做决定网站深圳seo网站优化
  • 上海网站建设沪icp备深圳有做网站的公司吗
  • 怎样做学校网站营业执照怎么申报年报
  • 厦门网站建设公司哪个好有域名有服务器怎么做网站
  • 上海免费网站建设品牌客户关系管理系统名词解释
  • 做电子请帖的网站qq网站代码
  • 音乐网站功能太原网站建设51sole
  • 微网站与移动开发是做什么的seo加盟代理