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

阿里云服务器做盗版视频网站佛山网站制作维护

阿里云服务器做盗版视频网站,佛山网站制作维护,公众号开发合同模板,济南网站设计制作要多久数字分组求偶数和 1.问题描述 问题描述 小M面对一组从 1 到 9 的数字,这些数字被分成多个小组,并从每个小组中选择一个数字组成一个新的数。目标是使得这个新数的各位数字之和为偶数。任务是计算出有多少种不同的分组和选择方法可以达到这一目标。 n…

数字分组求偶数和

1.问题描述

问题描述

小M面对一组从 1 到 9 的数字,这些数字被分成多个小组,并从每个小组中选择一个数字组成一个新的数。目标是使得这个新数的各位数字之和为偶数。任务是计算出有多少种不同的分组和选择方法可以达到这一目标。

  • numbers: 一个由多个整数字符串组成的列表,每个字符串可以视为一个数字组。小M需要从每个数字组中选择一个数字。

例如对于[123, 456, 789],14个符合条件的数为:147 149 158 167 169 248 257 259 268 347 349 358 367 369


测试样例

样例1:

输入:numbers = [123, 456, 789]
输出:14

样例2:

输入:numbers = [123456789]
输出:4

样例3:

输入:numbers = [14329, 7568]
输出:10

2.思路与题解

问题理解

你需要从每个数字组中选择一个数字,使得这些数字的和为偶数。问题的核心在于如何判断一个数的和是否为偶数。

数据结构选择

  • 输入是一个整数数组,每个整数可以转换为字符串来处理。
  • 你需要遍历每个数字组,并从每个组中选择一个数字。

算法步骤

  1. 转换输入:将整数数组转换为字符串数组,以便于处理每个数字组中的单个数字。
  2. 递归遍历:使用递归函数来遍历每个数字组,并从每个组中选择一个数字。
  3. 和的判断:在递归过程中,累加当前选择的数字,并在递归的终止条件处判断累加和是否为偶数。
  4. 计数:如果累加和为偶数,则计数加一。

2.4代码框架

Java

public class Main {public static int solution(int[] numbers) {// 将整数数组转换为字符串数组String[] numStrings = new String[numbers.length];for (int i = 0; i < numbers.length; i++) {numStrings[i] = String.valueOf(numbers[i]);}// 调用递归函数进行计算return countEvenSumCombinations(numStrings, 0, 0);}// 递归函数,用于计算符合条件的组合数private static int countEvenSumCombinations(String[] numStrings, int index, int currentSum) {// 如果已经遍历完所有数字组if (index == numStrings.length) {// 检查当前和是否为偶数if (currentSum % 2 == 0) {return 1;} else {return 0;}}int count = 0;// 遍历当前数字组中的每个数字for (char digit : numStrings[index].toCharArray()) {// 将字符转换为数字int num = digit - '0';// 递归调用,选择下一个数字组count += countEvenSumCombinations(numStrings, index + 1, currentSum + num);}return count;}public static void main(String[] args) {// 测试用例System.out.println(solution(new int[]{123, 456, 789}) == 14);System.out.println(solution(new int[]{123456789}) == 4);System.out.println(solution(new int[]{14329, 7568}) == 10);}
}

C++

#include <iostream>
#include <vector>
#include <string>int solution(std::vector<int> numbers) {int count = 0;// 遍历每个数字组for (int num : numbers) {std::string numStr = std::to_string(num);// 遍历数字组中的每个数字for (char digit : numStr) {// 计算和int sum = 0;// 计算各位数字之和// 判断和是否为偶数if (sum % 2 == 0) {count++;}}}return count;
}int main() {// You can add more test cases herestd::cout << (solution({123, 456, 789}) == 14) << std::endl;std::cout << (solution({123456789}) == 4) << std::endl;std::cout << (solution({14329, 7568}) == 10) << std::endl;return 0;
}

Python

def solution(numbers):def is_even_sum(digits):# 检查一组数字的和是否为偶数return sum(digits) % 2 == 0def count_even_sum_combinations(index, current_digits):# 如果已经遍历完所有数字组if index == len(numbers):# 检查当前组合的和是否为偶数if is_even_sum(current_digits):return 1return 0count = 0# 遍历当前数字组中的每个数字for digit in str(numbers[index]):# 选择当前数字并递归处理下一个数字组count += count_even_sum_combinations(index + 1, current_digits + [int(digit)])return count# 从第一个数字组开始递归计算return count_even_sum_combinations(0, [])if __name__ == "__main__":# 你可以添加更多测试用例print(solution([123, 456, 789]) == 14)print(solution([123456789]) == 4)print(solution([14329, 7568]) == 10)

Golang

package mainimport "fmt"func solution(numbers []int) int {// 辅助函数,用于判断一个数是否为偶数isEven := func(num int) bool {return num%2 == 0}// 递归函数,用于遍历所有可能的选择var dfs func(index int, currentSum int) intdfs = func(index int, currentSum int) int {// 如果已经遍历完所有数字组if index == len(numbers) {// 检查当前和是否为偶数if isEven(currentSum) {return 1}return 0}count := 0// 将当前数字组转换为字符串numStr := fmt.Sprintf("%d", numbers[index])// 遍历当前数字组中的每个数字for i := 0; i < len(numStr); i++ {// 将字符转换为数字digit := int(numStr[i] - '0')// 递归处理下一个数字组count += dfs(index+1, currentSum+digit)}return count}// 从第一个数字组开始递归return dfs(0, 0)
}func main() {// 你可以添加更多测试用例fmt.Println(solution([]int{123, 456, 789}) == 14)fmt.Println(solution([]int{123456789}) == 4)fmt.Println(solution([]int{14329, 7568}) == 10)
}

2.5一些疑难的代码解释

  1. 递归函数的设计:确保递归函数能够正确地遍历每个数字组,并累加当前选择的数字。
  2. 和的判断:在递归的终止条件处,判断累加和是否为偶数。
  3. 计数:如果累加和为偶数,则计数加一。

3.欢迎大佬们关注或莅临本渣的一些个人website

gitee: https://gitee.com/xiao-chenago
github:https://github.com/cool-icu0
语雀:https://www.yuque.com/icu0
csdn:https://cool-icu.blog.csdn.net/

http://www.yayakq.cn/news/468532/

相关文章:

  • 淄博手机网站建设怎么做一个个人网站
  • 如何做网站国际化设计网站 常用
  • 营销网站建设的步骤过程免费源码交易网站源码
  • 建设asp网站视频教程微网站功能
  • 网站制作的iis .net 网站架设
  • 南宁网站建站推广大通县wap网站建设公司
  • 淮安网站建设制作合肥政务区建站公司
  • 58网站为啥做不好wordpress音频付费插件
  • 泰安集团网站建设价格网站开发的最后5个阶段
  • 公司开发网站建设价格网站制作涉及哪些方面
  • 桂林网站开发公司雷神代刷网站推广快速
  • 信誉好的苏州网站建设钟祥网站制作
  • 如何免费搭建网站响应云网站模板下载
  • 苏州市住房和城乡建设局政务网站做网站用哪个服务器好
  • 北京建设质量协会网站济南网站设计开发
  • 找公司做网站需要买服务器河池市住房和城乡建设厅网站
  • 网站构建设计思路做网站设计的论文中摘要怎么写
  • 济南网站建设用途评测主题 wordpress
  • 无忧网站后台换网站公司
  • 杭州网站建设提供商企业网站建设的一般原则
  • 教育培训网站排名wordpress怎么删除目录下
  • 帮做动态头像的网站如何做一名网站编辑
  • 网站建设ppt方案无货源电商软件
  • 售票网站建设网站托管服务协议
  • 06627网页制作与网站建设莱芜都市网交友征婚
  • wordpress 网站卡北京附近做网站的公司有哪些
  • 张家界网站制作公司网站做好了 后期怎么做
  • vs2010网站开发 SQL温州论坛网站首页
  • 网站模版网jimdo和wordpress
  • 什么企业网站能自己做手机系统优化