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

建设网站的服务端口自己怎么免费做网站网页

建设网站的服务端口,自己怎么免费做网站网页,做英语陪同翻译兼职的网站,网站建设服务581. 双指针 双指针算法的核心思想:将暴力解法的时间复杂度,通常是O(N*N),通过某种特殊的性质优化到O(N)。 做题思路:先想想暴力解法的思路,然后分析这道题的特殊性质,一般是单调性。然后得出双指针算法的思路…

1. 双指针

双指针算法的核心思想:将暴力解法的时间复杂度,通常是O(N*N),通过某种特殊的性质优化到O(N)。

做题思路:先想想暴力解法的思路,然后分析这道题的特殊性质,一般是单调性。然后得出双指针算法的思路。

双指针算法的模板:

for(int i = 0; i <n; i++)

{

        while(j < i && check(i, j))

                j++;

        //具体题目的解题思路

}、

1.1 例题

给定一个长度为 n 的整数序列,请找出最长的不包含重复数数字的最长子序列,输出它的长度。

输入格式

第一行包含整数 n 。

第二行包含 n 个整数(均在0 ~ 100000范围内),表示整数序列。

输出格式

共一行,包含一个整数,表示最长的不包含重复数字的连续子序列的长度。

数据范围

1 <= n <= 100000

按照上面介绍的解题思路:我们先看看暴力解法怎么做的:两层for循环,外层循环在遍历数组时,对于外层循环遍历的每一个值,内层循环都会从该位置开始去遍历,通过检查区间内是否存在重复数字,更新结果。显然这种解法的事件复杂度为O(N*N)。伪代码如下:

for (int i = 0; i < n; i++)
{
    for (j = i + 1; j < n; j++)
    {
        if (!check(i, j))
            ret = max(ret, i - j + 1);
    }
}

其中n为数组的长度,check为检查区间 [ i, j ] 中的元素是否存在重复的数字,如果不存在更新结果,保存到ret中。

双指针:同样根据上面提供的解题思路,我们尝试从暴力解法中分析出单调性。嗯,双指针的左侧指针在整个查找过程中是单调的。怎么理解呢?

下面以一个具体的例子:1,2,2,3,5 来分析哈:

 现在我们已经知道了双指针的大致思路了,但是好像还没有弄清除单调性从何而来。对于本题单调性就是:在 i++ 向右找更大的满足要求的更长区间时,j不可能存在向前动 (j--) 的情况。即,本题中 j 具有单调性。

 弄清除了这些,我们只需要知到怎么判定一个区间中是否有重复元素就行了。我们可以初始化一个数组a,遍历原数组b, 得到的值假设为s,就让 a[s] + 1,代表这个数字出现了一次。注意当一个区间中没有重复元素时,i++,那么只有原数组中下标为 i 的 的值才会是重复的元素,因此我们只需要判断 a[b[i]] 的值是否是大于 1 即可。这就是模板中的 check 。另外本题中不要 i > j 这个条件,因为 i == j 时,区间 [j, i] 中就没有重复的元素了,i然后就会加一,即 j 是不会大于 i 的。

当区间内存在重复元素时,j++的同时要将 a[b[j]]--,少了一个数字嘛。

 现在可以写代码啦!

int main()
{const int N = 100000;//原数组int b[N];//统计数字出现次数的数组int a[N] = { 0 };//用于保存最大的区间长度int ret = 0;int j = 0;//读入数据int n;scanf("%d", &n);for (int i = 0; i < n; i++){scanf("%d", &b[i]);}//核心算法for (int i = 0; i < n; i++){a[b[i]]++;while (a[b[i]] > 1){//少一个数字,次数减一a[b[j]]--;j++;}//更新结果ret = ret > i - j + 1 ? ret : i - j + 1;}//打印结果printf("%d\n", ret);system("pause");return 0;
}

1.2 小试牛刀(来源:Acwing)

http://www.ds6.com.cn/news/43616.html

相关文章:

  • 免费制作网站net域名有效的网站推广方式
  • 网站的推广方式有哪些今天发生的重大新闻5条
  • 北京市住房和城乡建设委官方网站淘宝关键词搜索工具
  • php手机网站怎么做seo发外链工具
  • 湖南网站建设公司磐石网络旅游网站的网页设计
  • 甘南北京网站建设磁力链搜索引擎入口
  • 做的最好的网站公司需要推广的app在哪里找
  • 网站 稳定性广告关键词有哪些类型
  • 网站制作教程:初学者杭州seo网络推广
  • 许昌市网站建设网络营销和传统营销的区别和联系
  • 如何做不同域名跳转同一个网站网络营销推广策划的步骤
  • 互联网招聘网站排名沐浴露营销软文
  • 淮安汽车集团网站建设最靠谱的十大教育机构
  • 做系统之前的网站收藏在哪里看河南怎样做网站推广
  • 石家庄人口免费发seo外链平台
  • 品牌设计的要求有哪些江苏关键词推广seo
  • 邢台网站建设公司1688关键词排名查询工具
  • 沈阳做网站哪家最便宜代刷网站推广免费
  • 网站设计师联盟爱站长尾关键词挖掘工具
  • 网上花店网页设计实训报告品牌推广百度seo
  • 香港空间送网站网站设计与建设
  • 通江县城乡建设局门户网站产品软文模板
  • 企业做网站的发票会计分录客服外包平台
  • 免费做微信请帖的网站济南网站运营公司
  • 北京网站建设产品介绍seo外包公司多吗
  • 网站建设推广 seo百度关键词搜索引擎排名优化
  • 中期通网站建设2024年的新闻
  • 湘潭做网站口碑好磐石网络代写文章多少钱
  • 国内吃瓜爆料黑料网曝门湖南关键词优化品牌价格
  • 浦东网站建设宁波超值关键词优化