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

设计公司做网站有用吗jsp做网站毕业设计

设计公司做网站有用吗,jsp做网站毕业设计,建设网站招标文件,公司网站规划问题 注:大佬对此类问题的解法:动态规划背包问题总结 给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。 题目数据保证答案符合 32 位整数范围。 示例 1&#xff…

问题

注:大佬对此类问题的解法:动态规划背包问题总结
给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。

题目数据保证答案符合 32 位整数范围。

示例 1:

输入:nums = [1,2,3], target = 4
输出:7
解释:
所有可能的组合为:
(1, 1, 1, 1)
(1, 1, 2)
(1, 2, 1)
(1, 3)
(2, 1, 1)
(2, 2)
(3, 1)
请注意,顺序不同的序列被视作不同的组合。
示例 2:

输入:nums = [9], target = 3
输出:0

提示:

1 <= nums.length <= 200
1 <= nums[i] <= 1000
nums 中的所有元素 互不相同
1 <= target <= 1000

程序

#include <stdio.h>// 定义一个函数来计算总和为目标整数的元素组合的个数
int combinationSum4(int* nums, int numsSize, int target) {// 创建一个动态规划数组 dp,长度为 target + 1int dp[target + 1];// 初始化 dp 数组,将所有元素初始化为0for (int i = 0; i <= target; i++) {dp[i] = 0;}// 初始状态:总和为0时,只有一种组合方式,即什么都不选dp[0] = 1;// 开始填充 dp 数组for (int i = 1; i <= target; i++) {for (int j = 0; j < numsSize; j++) {// 如果当前的目标总和减去数组元素可达if (i - nums[j] >= 0) {// 则将 dp[i] 增加 dp[i - nums[j]],表示加上当前元素后的组合数dp[i] += dp[i - nums[j]];}}}// 返回 dp 数组中最终目标总和的组合数return dp[target];
}int main() {int nums[] = {1, 2, 3};int target = 4;int numsSize = sizeof(nums) / sizeof(nums[0]);// 调用 combinationSum4 函数,计算组合数int result = combinationSum4(nums, numsSize, target);// 打印结果printf("输出:%d\n", result);return 0;
}

解释

在动态规划中,dp[i - nums[j]] 表示以目标值 i 减去数组中的某个元素 nums[j] 后的状态。这通常用于动态规划问题中,特别是在处理组合问题时,来记录前一步的状态。

在上述程序中,dp[i] 表示总和为 i 的组合数。当计算 dp[i] 时,我们遍历数组 nums 中的元素,对于每个元素 nums[j],我们考虑将其加入总和为 i 的组合中。为了计算 dp[i],我们需要考虑两种情况:

  1. 如果 i 大于等于 nums[j],那么我们可以将 nums[j] 加入到总和为 i 的组合中。此时,我们需要考虑的是将 nums[j] 加入后,剩余的总和为 i - nums[j] 的组合数,这就是 dp[i - nums[j]]。
  2. 如果 i 小于 nums[j],则 nums[j] 不能被加入到总和为 i 的组合中,因为它会导致总和超过
    i。因此,在这种情况下,dp[i - nums[j]] 为0。

所以,dp[i - nums[j]] 表示以目标值 i 减去数组中的某个元素 nums[j] 后的状态,即剩余的部分。通过考虑所有可能的 nums[j],我们可以累加所有这些情况,以计算总和为 i 的组合数 dp[i]。这就是动态规划的思想:将较大问题分解成较小问题,并使用较小问题的解来构建较大问题的解。

假设数组 nums 为 [1, 2, 3],目标值 target 为 4。
初始时,dp 数组如下:

dp[0] = 1
dp[1] = 0
dp[2] = 0
dp[3] = 0
dp[4] = 0

开始计算 dp[1]:

  • i 等于 1,nums[j] 等于 1,因此 i >= nums[j]。
  • 我们考虑将 1 加入到总和为 1 的组合中,剩余的总和是 1 - 1 = 0。
  • 此时,dp[0] 为1,因为只有一种组合方式,即什么都不选。
  • 所以,dp[1] = dp[1 - 1] = dp[0] = 1。
    继续计算 dp[2] 和 dp[3]:
  • dp[2] 的计算和 dp[1] 类似,因为我们可以将 2 加入到总和为 2 的组合中,dp[2] = dp[2 - 2] = dp[0] = 1。
  • dp[3] 的计算也类似,因为我们可以将 3 加入到总和为 3 的组合中,dp[3] = dp[3 - 3] = dp[0] = 1。
    最后,计算 dp[4]:
  • 对于 dp[4],我们可以考虑将 1 加入到总和为 4 的组合中,这就是 dp[4 - 1] = dp[3] = 1。
  • 我们还可以考虑将 2 加入到总和为 4 的组合中,这就是 dp[4 - 2] = dp[2] = 1。
  • 同样,我们可以考虑将 3 加入到总和为 4 的组合中,这就是 dp[4 - 3] = dp[1] = 1。
  • 然后,将这些情况的组合数累加起来,即 dp[4] = 1 + 1 + 1 = 3。

最终,dp[4] 的值为 3,表示总和为 4 的组合数为 3 种,即 [1, 1, 1, 1]、[1, 1, 2] 和 [2, 2]。

http://www.15wanjia.com/news/177715.html

相关文章:

  • 郑州做网站的大公做网站去哪里投放广告
  • 网站主体负责人邮箱国家公示企业信息查询官网
  • 要想用谷歌访问外国网站怎么做wordpress网站评论插件
  • 电商网站建设行业现状qq腾讯官网登录入口
  • 邢路桥建设总公司网站福州seo招聘
  • 做网络调查的网站赚钱wordpress用户中心
  • 百度商桥代码怎么添加到网站西安网站建设最新案例
  • 公司网站案例展示wordpress版权修改文件
  • 蓝海国际版网站建设优酷的网站头怎么做的
  • 网站上社保做增员怎么做建设网站类型
  • 金山网站建设关键词排名网站建设目标论文
  • 网站百度不收录的原因深圳外贸网站定制
  • 房地网站制作电子商务网站开发策划
  • c 网站开发流程wordpress文章数据库表
  • 国外做软件界面的设计网站关于网站建设的书
  • 网站建设的实训总结黑龙江建设银行交通违法网站
  • 手机网站怎么做的好长春模板网站建站
  • 杭州网站开发品牌注册查询官网
  • 可以做彩页的网站图书馆网站建设的意义
  • 手机怎么开网站html教程菜鸟教程下载
  • 网站的免费空间是什么电子版简历
  • 免费网站建站平台厦门快速建网站
  • 庐山市建设规划局网站iis网站建设
  • 网站模板样式修改手机怎么做网站添加背景音乐
  • 网站建设网站需要什么西安推广公司
  • 红杭州网站建设wordpress 跨站
  • 环宇网站建设拓者设计吧手机版
  • 室内设计网站会员哪个值得买济南网络推广网络营销软件
  • 网站建设取得实效网络产品代理加盟
  • 福建省建设厅网站建造师证转出pycharm网站开发