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

武汉给政府做网站的公司人工智能培训心得

武汉给政府做网站的公司,人工智能培训心得,小程序官方示例,又顺又旺的公司名字大全300.最长递增子序列 这题的重点是DP数组的定义,子序列必须以nums[i]为最后一个元素,这样dp数组中后面的元素才能与前面的元素进行对比 1、DP数组定义:dp[i]表示以nums[i]为最后一个元素的最长递增子序列长度 2、DP数组初始化:全部…

300.最长递增子序列

这题的重点是DP数组的定义,子序列必须以nums[i]为最后一个元素,这样dp数组中后面的元素才能与前面的元素进行对比

1、DP数组定义:dp[i]表示以nums[i]为最后一个元素的最长递增子序列长度

2、DP数组初始化:全部初始化为1(子序列最少也有自身一个)

3、递推公式与 i 前所有元素进行对比,如果nums[i] > nums[j],那么更新dp[i]

        · 基本——dp[j]:位置 j 处的最长递增子序列

        · 新增—— +1:算上nums[i],多了一个递增元素

        · 最后的递推公式:dp[i]取较大值:dp[i] = std::max(dp[i], dp[j] + 1)

4、遍历顺序:从前向后遍历

int lengthOfLIS(vector<int>& nums) {// dp[i]表示以nums[i]为最后一个元素的最长递增子序列长度// 全部初始化为1(子序列最少也有自身一个)vector<int> dp(nums.size(), 1);int ans = 1;for (int i = 1; i < nums.size(); ++i) {// 与i之前的所有元素做比较for (int j = 0; j < i; ++j) {// 不断更新dp[i],寻找以nums[i]为最后一个元素的最长递增子序列长度if (nums[i] > nums[j])dp[i] = std::max(dp[i], dp[j] + 1);}// 记录过程中的最长子序列if (dp[i] > ans)ans = dp[i];}return ans;
}

 674.最长连续递增序列

 整体和上一题差不多,但由于要求是“连续”子序列,所以简单不少。主要差别在遍历过程中,为了保持序列连续,只需要与前一个元素对比即可(上一题需要与前面所有元素对比)。

int findLengthOfLCIS(vector<int>& nums) {vector<int> dp(nums.size(), 1);int ans = 1;for (int i = 1; i < nums.size(); ++i) {// 只需要与 i - 1 比较if (nums[i] > nums[i - 1]) {dp[i] = dp[i - 1] + 1;ans = std::max(ans, dp[i]);}}return ans;
}// 压缩空间写法
iint findLengthOfLCIS(vector<int>& nums) {int dp = 1;int ans = 1;for (int i = 1; i < nums.size(); ++i) {if (nums[i] > nums[i - 1])ans = std::max(ans, ++dp);elsedp = 1;}return ans;
}

718.最长重复子数组

写暴力超时了,剪剪枝可能有机会过?

int findLength0(vector<int>& nums1, vector<int>& nums2) {// 尝试用哈希表来加快索引// key:值// value:出现值的下标unordered_map<int, vector<int>> mapNum2;for (int i = 0; i < nums2.size(); ++i) {auto it = mapNum2.find(nums2[i]);if (it == mapNum2.end())mapNum2.insert({ nums2[i], {i} });elseit->second.push_back(i);}vector<int> dp(nums1.size(), 0);int ans = 0;// 暴力两层循环 + 最内层判断重复子序列长度for (int i = 0; i < nums1.size(); ++i) {auto it = mapNum2.find(nums1[i]);if (it == mapNum2.end())continue;ans = std::max(ans, 1);for (int k : it->second) {int len = 1;for (int j = 1; i + j < nums1.size() && k + j < nums2.size(); ++j) {if (nums1[i + j] == nums2[k + j]) {dp[i + j] = std::max(dp[i + j], ++len);ans = std::max(ans, dp[i + j]);}elsebreak;}}}return ans;
}

动规写法:

这题重点也是DP数组的定义:两个序列所以DP数组用二维

1、DP数组定义:两个维度表示两个数组的索引,dp[i][j]表示以nums1[i - 1]nums2[j - 1]为结尾的两个字符串的最长重复子数组长度

        (子序列问题一般都定义为 i - 1j - 1,目的是精简初始化的步骤)

2、DP数组初始化:首行与首列元素无意义,但为了递推公式将其初始化为0,其余元素随意

3、递推公式:如果nums1[i - 1] == nums2[j - 1],那么dp[i][j] = dp[i - 1][j - 1] + 1

        · 基本——dp[i - 1][j - 1]:以nums1[i - 2]和nums2[j - 1]为结尾的两个字符串的最长重复子数组长度

        · 新增—— +1:加上新的这对匹配元素

        · 最后的递推公式:dp[i] = std::max(dp[i], dp[j] + 1)

4、遍历顺序:从上到下从左到右遍历,先遍历nums1或nums2都可以

int findLength(vector<int>& nums1, vector<int>& nums2) {// dp[i][j]表示以nums1[i - 1]和nums2[j - 1]为结尾的两个字符串的最长重复子数组长度// 首行与首列元素无意义,为了递推公式将其初始化为0vector<vector<int>> dp(nums1.size() + 1, vector<int>(nums2.size() + 1, 0));int ans = 0;for (int i = 1; i <= nums1.size(); ++i) {for (int j = 1; j <= nums2.size(); ++j) {if (nums1[i - 1] == nums2[j - 1]) {// dp[i][j]的值由dp[i - 1][j - 1]递推得到dp[i][j] = dp[i - 1][j - 1] + 1;ans = std::max(ans, dp[i][j]);}}}return ans;
}
http://www.hengruixuexiao.com/news/13236.html

相关文章:

  • 哪个网站可以做任务赚钱深圳最新政策消息
  • dw怎么做网站轮播图什么是论坛推广
  • 如何对网站管理肇庆seo按天收费
  • 怎样做网站流量可以入侵的网站
  • 哪个网站做译员好网络营销推广技巧
  • 金融投资网站 php源码网站检测工具
  • 美乐乐网站模板威海seo公司
  • php网站开发外包引擎优化seo是什么
  • php网站开发集合教程自己怎样推广呢
  • 做网站 (公司)郑州纯手工seo
  • 电子商务网站建设试题全网整合营销公司
  • 做网站南昌搜索竞价托管
  • 东营网站建设哪家好今天重大新闻头条新闻
  • 做海报素材网站推荐今日国内新闻大事20条
  • 武汉网站设计公司推荐视频号直播推广二维码
  • 惠州高端网站建设新闻头条今日要闻最新
  • 给别人做网站赚钱落实好疫情防控优化措施
  • 中工信融做网站怎么样职业技能培训平台
  • wordpress 标题换行优化教程网官网
  • 利用国外网站文章图片做书营利关键词搜索工具好站网
  • 网站后台管理产品排序企业营销平台
  • 响应式网站是指自适应吗短视频搜索seo
  • 手机网站素材学推广网络营销去哪里
  • 怎样制作自己公司的网站一个自己的网站
  • 深圳建网站好的公司拼多多网店代运营要多少费用
  • 成都哪家做网站建设比较好销售外包
  • spring mvc 做网站深圳网络营销推广服务
  • 北京网站搭建多少钱杭州网络推广有限公司
  • 面向服务的关系建设网站怎么做网络推广优化
  • 亚马逊做图片链接的网站百度搜索资源平台token