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

asp.net 网站建设方案微信引流主动被加软件

asp.net 网站建设方案,微信引流主动被加软件,做网站平台多少钱,有哪些做拎包入住的网站题目链接 文章目录 1. 思路讲解1.1 dp表的创建1.2 状态转移方程1.3 使用哈希表找到k1.4 初始化1.5 返回值1.6 该题坑爹的一点 2. 代码编写 1. 思路讲解 我们要知道以某个位置为结尾的子序列的数量,可以通过它的以上一位置的为结尾的子序列的数量得知,也…

题目链接

文章目录

  • 1. 思路讲解
    • 1.1 dp表的创建
    • 1.2 状态转移方程
    • 1.3 使用哈希表找到k
    • 1.4 初始化
    • 1.5 返回值
    • 1.6 该题坑爹的一点
  • 2. 代码编写

1. 思路讲解

我们要知道以某个位置为结尾的子序列的数量,可以通过它的以上一位置的为结尾的子序列的数量得知,也就是说,这是一个dp问题。

1.1 dp表的创建

dp问题我们需要创建dp表,如果我们单纯使用dp[i]来表示以 i 位置为结尾的子序列的数量是完全不够的。因为我们不知道以 i-1 位置为结尾的等差数列是怎样的,它的公差是几我们是不知道的。也就是说,我们不确定 i 位置的元素是否能跟到以 i - 1 位置为结尾的数列的后面。

但是,如果知道了数列的后两个元素,也就是知道了 i - 1 位置以及数列中上一个位置的元素,就能知道数列的公差了,也就能知道 i 位置的元素是否能跟到后面了,所以我们需要用两个元素来表示每个dp位置。

创建二维dp表,dp[i][j]表示以 i 位置的元素为数列倒数第二个元素,以 j 位置的元素为数列倒数第一个元素,为结尾的数列数量有多少。(我们人为规定i < j)

1.2 状态转移方程

nums[j] - nums[i]可以得到公差,再由 num[i] - 公差 可以得到上一项的值,记为 a,我们需要知道这个 a 值在nums中是否存在且是否在 i 位置的前面,两个条件都满足才符合题意。

记 a 在nums中的下标为k(至于怎么找到这个k下面会说),我们要找到以 i 和 j 位置为结尾的等差数列的个数,其实找到所有 k 和 i 位置元素结尾的等差数列的个数相加即可(a元素在nums中的位置不只一个,那么k可能就不只一个)。并且也需额外加上一个数列,就是 k,i ,j,本身所构成的等差数列。

那么状态转移方程就为:dp[i][j] += dp[k][i] + 1

1.3 使用哈希表找到k

我们写代码的时候,遍历所有 i 和 j 的组合,时间复杂度就已经到达 N^2 了,如果此时再在数组中去寻找 k ,那么时间复杂度就 N^3了,这大概率是会超时的。

我们可以在dp之前,使用哈希表去将<所有元素,数组下标>绑定在一起,放在哈希表中,这样我们得到了 a 之后,就可以使用哈希表很快地查找到 k 了。

1.4 初始化

刚开始,以 i,j 位置为结尾,只有两个元素,不符合题目中的等差数列,可以记为 0 ,所以我们初始化的时候将dp表中所有的值初始化为 0 即可。又因为,vector会默认初始化为0,所以我们不用手动初始化了。

1.5 返回值

我们要求的是所有的等差数列,所以我们要将所有符合题意的dp[i][j]都加起来然后返回。

1.6 该题坑爹的一点

虽然题目已经说了,返回值以及各个元素的值都在int范围内,但是我们求a的时候,a的值可能会超出int的范围从而出错,所以我们将a的类型要设置为long long。然后用a查找k用的是hash,所以hash的第一个类型也要为long long。

2. 代码编写

在这里插入图片描述

class Solution {
public:int numberOfArithmeticSlices(vector<int>& nums) {int n = nums.size();// 创建哈希表,便于很快地找到k// 因为k不只一个,所以用vector来存储unordered_map<long long, vector<int>> hash;for (int i = 0; i < n; i++) hash[nums[i]].push_back(i);// 创建二维dp表,第一维为数列的倒数第二个元素,第二维为数列的倒数第一个元素vector<vector<int>> dp(n, vector<int>(n));int ret = 0; // 所有数组的数量// i为nums第0个位置时,不管j为几,dp[0][j]都为0,因为只有两个元素// 所以从第1个位置开始填表即可,且i一定不为nums最后一个元素for (int i = 1; i < n - 1; ++i){// j从i+1开始,一直到最后一个位置,寻找符合题意的情况for (int j = i + 1; j < n; ++j){long long a = (long long)2*nums[i] - nums[j];if (hash.count(a)) // 看a是否存在于hash中{// 如果存在,遍历a对应的vectorfor (auto k : hash[a]){// k需要小于iif (k < i) dp[i][j] += dp[k][i] + 1;}} ret += dp[i][j];}}return ret;}
};
http://www.jinmujx.cn/news/120015.html

相关文章:

  • wordpress官方文档seo网站排名优化工具
  • 建设网站的费用如何账务处理企业怎么做好网站优化
  • 省级住房城乡建设主管部门网站太原seo外包服务
  • 电视网站免费大全百度关键词搜索怎么弄
  • 广州高端网站制作公司成都网络营销策划
  • 网站建设好友google优化推广
  • 济南做网站推广哪家好厦门seo排名外包
  • 常见的建站工具湖南最新消息今天
  • 做网站开发的营业执照新闻10条摘抄大全
  • 做网站要用什么编程语言全国广告投放平台
  • 名城苏州网站百度扫一扫网页版
  • 网站建设灬金手指下拉百度导航如何设置公司地址
  • 网站兼容性测试怎么做今日热搜榜
  • 网站建设全程揭秘合肥关键词排名技巧
  • 建设企业网站用动态还是静态湖南省人民政府官网
  • wordpress禁用媒体库seo短视频入口
  • 网站开网站开发设计公司营销托管全网营销推广
  • 创立外包网站市场营销专业
  • 大良营销型网站设计公司seo关键词优化要多少钱
  • 做网站运营需要做哪些阿里云免费域名
  • asp.net 4.0网站建设基础教程企业网站建设方案范文
  • 旅游网站作用网站优化基本技巧
  • 马鞍山网站建设公司排名站长素材网站官网
  • 沈阳网站推广的公司百度云资源搜索
  • 全民建网站公司做网站需要多少钱
  • 鹰潭网站制作流量平台排名
  • html5企业网站开发竞价关键词优化软件
  • 建设商城类网站多少钱热狗seo优化外包
  • 网站建设为了什么最新新闻消息
  • 网站建立的具体步骤google 推广优化