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

深圳建设网站费用seo搜索引擎优化网站

深圳建设网站费用,seo搜索引擎优化网站,宁波seo网络优化哪家好,php与网站开发🌹作者:云小逸 📝个人主页:云小逸的主页 📝Github:云小逸的Github 🤟motto:要敢于一个人默默的面对自己,强大自己才是核心。不要等到什么都没有了,才下定决心去做。种一颗树,最好的时间是十年前…

🌹作者:云小逸
📝个人主页:云小逸的主页
📝Github:云小逸的Github
🤟motto:要敢于一个人默默的面对自己,强大自己才是核心。不要等到什么都没有了,才下定决心去做。种一颗树,最好的时间是十年前,其次就是现在!学会自己和解,与过去和解,努力爱自己。==希望春天来之前,我们一起面朝大海,春暖花开!==🤟
👏专栏:C++👏 👏专栏:Java语言👏👏专栏:Linux学习👏
👏专栏:C语言初阶👏👏专栏:数据结构👏👏专栏:备战蓝桥杯👏

文章目录

  • 前言
  • 例题:我在哪?
    • 题目:
    • 输入格式
    • 输出格式
    • 数据范围
    • 输入样例:
    • 输出样例:
    • 暴力解法( On4):
      • 思想:
      • 代码:
    • 二分 + STL Set O(n^2^logn)
      • 思想:
      • 代码:
  • 最后


前言

今天这篇文章,我们继续学习二分法,这里讲解有一道有关二分的算法题:我在哪?

——————————————————————————————

首先先写上几句话:献给坚持创作的我和点开这篇文章希望进步的你
1.学不进去的时候就看看这段话:
“你考的不是试,是前途和暮年的欢喜,你桌面上的书本,是将来做选择时的意气和拒绝时的底气。” ​​​

2.“要是想哭的话,把能做的事情全部做完之后再尽情地哭。”

3.“我想向自己证明,我从未停止努力,我从未选择放弃,所以我一定能再回顶峰。”

4.“我们每个人都像陨石,即便终将陨落,也请我们尽情燃烧。”

5.“假如你什么都不学习,那就只能生活在现时现世的一个小圈子里,狭窄得很。”

例题:我在哪?

题目:

农夫约翰出门沿着马路散步,但是他现在发现自己可能迷路了!
沿路有一排共 N 个农场。不幸的是农场并没有编号,这使得约翰难以分辨他在这条路上所处的位置。然而,每个农场都沿路设有一个彩色的邮箱,所以约翰希望能够通过查看最近的几个邮箱的颜色来唯一确定他所在的位置。每个邮箱的颜色用 A…Z 之间的一个字母来指定,所以沿着道路的 N
个邮箱的序列可以用一个长为 N 的由字母 A…Z 组成的字符串来表示。某些邮箱可能会有相同的颜色。
约翰想要知道最小的 K 的值,使得他查看任意连续 K 个邮箱序列,他都可以唯一确定这一序列在道路上的位置。
例如,假设沿路的邮箱序列为 ABCDABC 。
约翰不能令 K=3,因为如果他看到了 ABC,则沿路有两个这一连续颜色序列可能所在的位置。

最小可行的 K 的值为 K=4,因为如果他查看任意连续 4 个邮箱,那么可得到的连续颜色序列可以唯一确定他在道路上的位置。

输入格式

输入的第一行包含 N,第二行包含一个由 N 个字符组成的字符串,每个字符均在 A…Z 之内。

输出格式

输出一行,包含一个整数,为可以解决农夫约翰的问题的最小 K 值。

数据范围

1≤N≤100

输入样例:

7
ABCDABC

输出样例:

4

暴力解法( On4):

思想:

可以直接进行枚举两个子串并比较,如:
写四个for循环:
第一个:先枚举k
第二个:枚举其中任意一个子串,k值一定,只要枚举起点就可以了
第三个:再枚举第二个子串,
第四个:判断两个子串是否相同:
N最大是100,四次方是1个亿,刚好可以过:而且它是达不到最大一个亿的,有的时候直接break了
在这里插入图片描述

代码:

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;int n;
string str;int main()
{cin >> n >> str;for (int k = 1; k <= n; k ++ )//先枚举k{bool flag = false;for (int i = 0; i + k - 1 < n; i ++ )//枚举其中任意一个子串,k值一定,只需要枚举起点就可以了{for (int j = i + 1; j + k - 1 < n; j ++ )//再枚举第二个子串{bool same = true;for (int u = 0; u < k; u ++ )//判断两个子串是否相同if (str[i + u] != str[j + u]){same = false;break;}if (same){flag = true;break;}}if (flag) break;}if (!flag){cout << k << endl;break;}}return 0;
}

在这里插入图片描述

二分 + STL Set O(n2logn)

思想:

判断是否可以二分,要看它是否有二段性:
在这里插入图片描述
假设ans为正确答案【最小的k】,故小于ans都是不合法的,大于ans都是合法的。故其具有二段性,那么就可以使用二分法来二分出分界点了,这样可以把上面的暴力法的第一次循环改为二分,这样复杂度就变成了O(n3logn)。
继续分析:
我们题意是想统计每一个串是否只出现一次,然而判断一个东西只出现一次,可以使用哈希表,
将每一个串映射到哈希表里,然后判断每一串是否只出现一次,这样可以再去掉一个循环,复杂度变成O(n2logn);

代码:

#include <iostream>
#include <cstring>
#include <algorithm>
#include <unordered_set>using namespace std;int n;
string str;
unordered_set<string> S;bool check(int mid)
{S.clear();for (int i = 0; i + mid - 1 < n; i ++ ){string s = str.substr(i, mid);if (S.count(s)) return false;S.insert(s);}return true;
}int main()
{cin >> n >> str;int l = 1, r = n;while (l < r){int mid = l + r >> 1;if (check(mid)) r = mid;else l = mid + 1;}cout << r << endl;return 0;
}

最后

十分感谢你可以耐着性子把它读完和我可以坚持写到这里,送几句话,对你,也对我:

1.“我们永远也不知道下一刻会发生什么,我只是觉得,还有希望的时候,不要选择放弃。”

2.“生活坏到一定程度就会好起来,因为它无法更坏,努力过后,才知道许多事情,坚持坚持,就过来了。

3.“在无人问津的地方历练,在万众瞩目的地方出现。”

4.“如果你第一步不迈出,永远不知道你的梦想是多么容易实现。”

5.“虽然绿灯没怎么为我亮过,但我还是对生活充满了希望。”

最后如果觉得我写的还不错,请不要忘记点赞✌,收藏✌,加关注✌哦(。・ω・。)

愿我们一起加油,奔向更美好的未来,愿我们从懵懵懂懂的一枚菜鸟逐渐成为大佬。加油,为自己点赞!


文章转载自:

http://IhW0FBGd.rnzgf.cn
http://SLxIWVwC.rnzgf.cn
http://FMZ5iNJU.rnzgf.cn
http://kOTpKLZx.rnzgf.cn
http://SEF0pJ0F.rnzgf.cn
http://CUF558V3.rnzgf.cn
http://5MFCJi8a.rnzgf.cn
http://YCkrVYSU.rnzgf.cn
http://JVLsT3Ie.rnzgf.cn
http://u0yz4l0h.rnzgf.cn
http://AFiTGIBf.rnzgf.cn
http://7hTHxXmi.rnzgf.cn
http://LvrQF4Yl.rnzgf.cn
http://wNA8lV8n.rnzgf.cn
http://I5fG3rAD.rnzgf.cn
http://8evWK9y0.rnzgf.cn
http://ZLoUojaF.rnzgf.cn
http://pdezqhjJ.rnzgf.cn
http://a5EPK9qY.rnzgf.cn
http://2Jalabq1.rnzgf.cn
http://7ldGa5dp.rnzgf.cn
http://1B6udWx9.rnzgf.cn
http://fzQibq06.rnzgf.cn
http://fCHOob0k.rnzgf.cn
http://8ReiFatL.rnzgf.cn
http://tWJsj2zE.rnzgf.cn
http://0uVYL5LF.rnzgf.cn
http://KRf5pLfF.rnzgf.cn
http://VL1xH4Xx.rnzgf.cn
http://laxhHsMp.rnzgf.cn
http://www.dtcms.com/wzjs/701082.html

相关文章:

  • 最好的微网站建设公司推荐宁波广告公司网站建设
  • 网站建设 三合一欧洲外贸服务器
  • 内网建设网站需要什么条件设计平台官网
  • 网站别人给我做的备案 我能更改吗谷歌网站 百度
  • 建设小的电商网站开源系统开发网站建设的问卷调查
  • 营销网站的功能构成哪里有免费网站空间申请
  • 河北建设厅八大员报名网站有什么方法在淘宝发布网站建设设计
  • 微网站一键导航企业网站首页设计评价
  • 北京电商网站建设哪家好国外网站流量
  • 做网站大概多钱做网站套餐
  • 西安网站建设有那些公司做学生阅读分析的网站
  • 网站 目标怎么在搜索引擎里做网站网页
  • 建站公司费用情况酒店vi设计
  • 青岛黄岛网站建设网站如何进行seo
  • 网站建设教程金旭亮北京科技公司10强
  • 中国建设工程造价管理网站空间设计说明怎么写
  • 长沙蒲公英网站建设如何快速网络推广产品的方法
  • 网站开发的调研内容wordpress 关键词优化
  • 网站建设系统服务机构编程加盟
  • 沈阳沈河seo网站排名优化商业网站模板下载
  • 做网站公司需要准备资料淘宝搜索词排名查询
  • 做网站需要投标吗免费建各种网站
  • 做p2p网站多少钱网站框架设计
  • 公司网站是不是每天要更新福建微网站建设
  • 杭州做网站公司有哪些要给公司做一个网站怎么做的
  • 营销型建设网站公司无极县在线招聘信息
  • 搞好姓氏源流网站建设forum wordpress
  • 北京网站开发多少钱移动互联网应用技术专业学什么
  • 南海营销网站开发民营医院建设网站
  • 微网站趋势wordpress能做图片站