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

郑州做网站推广多少钱楚雄今日头条新闻

郑州做网站推广多少钱,楚雄今日头条新闻,郑州淘宝网站建设,如何建设 营销型 网站作者推荐 动态规划的时间复杂度优化 本文涉及知识点 数位 数论 LeetCode2999. 统计强大整数的数目 给你三个整数 start ,finish 和 limit 。同时给你一个下标从 0 开始的字符串 s ,表示一个 正 整数。 如果一个 正 整数 x 末尾部分是 s &#xff08…

作者推荐

动态规划的时间复杂度优化

本文涉及知识点

数位 数论

LeetCode2999. 统计强大整数的数目

给你三个整数 start ,finish 和 limit 。同时给你一个下标从 0 开始的字符串 s ,表示一个 正 整数。
如果一个 正 整数 x 末尾部分是 s (换句话说,s 是 x 的 后缀),且 x 中的每个数位至多是 limit ,那么我们称 x 是 强大的 。
请你返回区间 [start…finish] 内强大整数的 总数目 。
如果一个字符串 x 是 y 中某个下标开始(包括 0 ),到下标为 y.length - 1 结束的子字符串,那么我们称 x 是 y 的一个后缀。比方说,25 是 5125 的一个后缀,但不是 512 的后缀。
示例 1:
输入:start = 1, finish = 6000, limit = 4, s = “124”
输出:5
解释:区间 [1…6000] 内的强大数字为 124 ,1124 ,2124 ,3124 和 4124 。这些整数的各个数位都 <= 4 且 “124” 是它们的后缀。注意 5124 不是强大整数,因为第一个数位 5 大于 4 。
这个区间内总共只有这 5 个强大整数。
示例 2:
输入:start = 15, finish = 215, limit = 6, s = “10”
输出:2
解释:区间 [15…215] 内的强大整数为 110 和 210 。这些整数的各个数位都 <= 6 且 “10” 是它们的后缀。
这个区间总共只有这 2 个强大整数。
示例 3:
输入:start = 1000, finish = 2000, limit = 4, s = “3000”
输出:0
解释:区间 [1000…2000] 内的整数都小于 3000 ,所以 “3000” 不可能是这个区间内任何整数的后缀。
提示:
1 <= start <= finish <= 1015
1 <= limit <= 9
1 <= s.length <= floor(log10(finish)) + 1
s 数位中每个数字都小于等于 limit 。
s 不包含任何前导 0 。

数论

len1 = s.length s1 = 下届.right(len1) s2 = 上届.right(len1)
枚举合法数字的长度len2。
我们当前数字假定除掉作为后缀的s,余下的部分为x,x的len = len2- len1。统计x的可能数量。难点:上下界可能包括limit以外的数字。
分类讨论:
一,x就是下界的前缀。
二,x就是上界的前缀。
三,x同时是上下界的前缀,做特殊处理,此时情况四不会存在。return (s1<=s)&&(s <= s2);
四,x 在上下界前缀之间。
处理余下的三种情况:
一,下界的前缀不包括limit及以上数字且s1 <= s,数量+1。
二,上界的前缀不包括limit及以上数字且s <= s2,数量+1。
三,小于上界前缀的数量-小于下界前缀的数量-等于下届前缀的数量。加上s后,一定在上下界之间。
等于下届前缀的数量:如果下届前缀不包括limit及以上数字,为1;否则为0。
小于下界(上界)前缀t的数量:
小于t的数量必定有j位前缀相同,j ∈ [ 0 , l e n ) \in[0,len) [0,len) 枚举j。
bitMin = (0==j)?1:0 最高位不能是0,其它位可以为0。
∑ j : 0 l e n − 1 ( m i n ( t [ j ] , l i m i t + 1 ) − b i t M i n ) × ( l i m i t + 1 ) l e n − j − 1 \sum_{j:0}^{len-1}(min(t[j],limit+1)-bitMin)\times (limit+1)^{len-j-1} j:0len1(min(t[j],limit+1)bitMin)×(limit+1)lenj1
就是当前位的取值数量 乘以 后面各位的取值数量。如果s[j]>=limit,则不会存在(j+1)位及更多位前缀相等。提前退出循环。

代码

核心代码

class Solution {
public:long long numberOfPowerfulInt(long long start, long long finish, int limit, string s) {m_s = s;m_limit = limit;const string strLow = std::to_string(start);const string strUp = std::to_string(finish);const int len0 = strLow.length();const int len = strUp.length();		m_vUnit.emplace_back(1);for (int i = 1; i <= 15; i++){m_vUnit.emplace_back(m_vUnit.back() * (limit+1));}if (len0 == len){return Do(strLow, strUp);}long long llRet = 0;llRet += Do(strLow, string(len0, limit+ '0'));for (int i = len0+1; i < len; i++){llRet += Do(("1" + string(i - 1, '0')).c_str(), string(i, limit + '0').c_str());}	llRet +=Do (("1" + string(len - 1, '0')).c_str(), strUp.c_str());return llRet;}long long Do(string strLow, string strUp){const int len = strLow.length() - m_s.length();if (len < 0 ){return 0;}auto [llCnt1, bVilid1] = LessEqual(len, strLow);auto [llCnt2, bVilid2] = LessEqual(len, strUp);bool b1 = (strLow.substr(len) <= m_s) && (bVilid1);bool b2 = (strUp.substr(len) >= m_s) && (bVilid2);if (strLow.substr(0,len) == strUp.substr(0,len)){return b1 && b2;}return (llCnt2 - llCnt1 - (bVilid1&&len)) + b1 + b2;}std::pair<long long, bool> LessEqual(int len,const string& s ){bool bVilid = true;long long llCnt = 0;for (int i = 0; i < len; i++){//计算小于数量const int bitMin = (0 == i) ? 1 : 0;if (bVilid){llCnt += (min(s[i] - '0', m_limit + 1) - bitMin) * m_vUnit[len - i - 1];}if (s[i] > m_limit + '0'){bVilid = false;}		}return make_pair(llCnt, bVilid);}vector<long long> m_vUnit;string m_s;int m_limit;
};

测试用例

template<class T,class T2>
void Assert(const T& t1, const T2& t2)
{assert(t1 == t2);
}template<class T>
void Assert(const vector<T>& v1, const vector<T>& v2)
{if (v1.size() != v2.size()){assert(false);return;}for (int i = 0; i < v1.size(); i++){Assert(v1[i], v2[i]);}}int main()
{long long start, finish;int limit;string s;{Solution sln;start = 1, finish = 1000000000000000, limit = 5, s = "1000000000000000";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(1, res);}{Solution sln;start = 1829505, finish = 1955574, limit = 7, s = "11223";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(0, res);}{Solution sln;start = 5398, finish = 6415, limit = 8, s = "101";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(1, res);}{Solution sln;start = 1, finish = 6000, limit = 4, s = "124";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(5, res);}{Solution sln;start = 15, finish = 215, limit = 6, s = "10";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(2, res);}{Solution sln;start = 10, finish = 1844, limit = 5, s = "12";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(12, res);}{Solution sln;start = 1, finish = 2000, limit = 8, s = "1";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(162, res);}{Solution sln;start = 1829505, finish = 1255574165, limit =7, s = "11223";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(5470, res);}{Solution sln;start = 15398, finish = 1424153842, limit = 8, s = "101";auto res = sln.numberOfPowerfulInt(start, finish, limit, s);Assert(783790, res);}}

优化

n位数,可以看成包括(m-n)个前置0的m位数。

class Solution {
public:long long numberOfPowerfulInt(long long start, long long finish, int limit, string s) {m_s = s;m_limit = limit;string strLow = std::to_string(start);const string strUp = std::to_string(finish);if (strLow.length() < strUp.length()){strLow = string(strUp.length() - strLow.length(), '0')+strLow;}		m_vUnit.emplace_back(1);for (int i = 1; i <= 15; i++){m_vUnit.emplace_back(m_vUnit.back() * (limit+1));}return Do(strLow, strUp);}long long Do(string strLow, string strUp){const int len = strLow.length() - m_s.length();if (len < 0 ){return 0;}auto [llCnt1, bVilid1] = LessEqual(len, strLow);auto [llCnt2, bVilid2] = LessEqual(len, strUp);bool b1 = (strLow.substr(len) <= m_s) && (bVilid1);bool b2 = (strUp.substr(len) >= m_s) && (bVilid2);if (strLow.substr(0,len) == strUp.substr(0,len)){return b1 && b2;}return (llCnt2 - llCnt1 - (bVilid1&&len)) + b1 + b2;}std::pair<long long, bool> LessEqual(int len,const string& s ){bool bVilid = true;long long llCnt = 0;for (int i = 0; i < len; i++){//计算小于数量if (bVilid){llCnt += (min(s[i] - '0', m_limit + 1) - 0) * m_vUnit[len - i - 1];}if (s[i] > m_limit + '0'){bVilid = false;}		}return make_pair(llCnt, bVilid);}vector<long long> m_vUnit;string m_s;int m_limit;
};

文章转载自:
http://flabellate.zLrk.cn
http://piccanin.zLrk.cn
http://chesterfieldian.zLrk.cn
http://gyrograph.zLrk.cn
http://nonlife.zLrk.cn
http://babette.zLrk.cn
http://apophthegmatic.zLrk.cn
http://halogenide.zLrk.cn
http://standfast.zLrk.cn
http://pittosporum.zLrk.cn
http://havildar.zLrk.cn
http://mohammed.zLrk.cn
http://laurasia.zLrk.cn
http://crustacea.zLrk.cn
http://anthropophuism.zLrk.cn
http://brassiere.zLrk.cn
http://talea.zLrk.cn
http://bauson.zLrk.cn
http://uncomplimentary.zLrk.cn
http://foraminiferous.zLrk.cn
http://superheater.zLrk.cn
http://hanukkah.zLrk.cn
http://streuth.zLrk.cn
http://coagulable.zLrk.cn
http://netware.zLrk.cn
http://megalecithal.zLrk.cn
http://chamberlain.zLrk.cn
http://sparsely.zLrk.cn
http://coltsfoot.zLrk.cn
http://semimechanical.zLrk.cn
http://fastening.zLrk.cn
http://unitage.zLrk.cn
http://espantoon.zLrk.cn
http://gnathion.zLrk.cn
http://mavournin.zLrk.cn
http://sinapin.zLrk.cn
http://cleavable.zLrk.cn
http://fress.zLrk.cn
http://katharevousa.zLrk.cn
http://head.zLrk.cn
http://domical.zLrk.cn
http://unlucky.zLrk.cn
http://ywca.zLrk.cn
http://ultrasonic.zLrk.cn
http://preconize.zLrk.cn
http://kenbei.zLrk.cn
http://poster.zLrk.cn
http://uveitis.zLrk.cn
http://rochdale.zLrk.cn
http://kmps.zLrk.cn
http://manning.zLrk.cn
http://mazu.zLrk.cn
http://reformist.zLrk.cn
http://decker.zLrk.cn
http://stockade.zLrk.cn
http://westie.zLrk.cn
http://alumroot.zLrk.cn
http://irkutsk.zLrk.cn
http://triplicity.zLrk.cn
http://auscultate.zLrk.cn
http://baldfaced.zLrk.cn
http://spoilt.zLrk.cn
http://discography.zLrk.cn
http://plausibly.zLrk.cn
http://influencing.zLrk.cn
http://universalize.zLrk.cn
http://entoblast.zLrk.cn
http://aspire.zLrk.cn
http://multimedia.zLrk.cn
http://rollout.zLrk.cn
http://lanuginousness.zLrk.cn
http://spruit.zLrk.cn
http://pavement.zLrk.cn
http://joyfully.zLrk.cn
http://cheskey.zLrk.cn
http://bilestone.zLrk.cn
http://drearily.zLrk.cn
http://salpingolysis.zLrk.cn
http://sickee.zLrk.cn
http://octopodes.zLrk.cn
http://levogyrate.zLrk.cn
http://erosible.zLrk.cn
http://cornelian.zLrk.cn
http://booming.zLrk.cn
http://casuarina.zLrk.cn
http://opacus.zLrk.cn
http://polyphagy.zLrk.cn
http://banshee.zLrk.cn
http://submental.zLrk.cn
http://earthfast.zLrk.cn
http://spadger.zLrk.cn
http://hedgehop.zLrk.cn
http://diphenoxylate.zLrk.cn
http://thallic.zLrk.cn
http://saturnic.zLrk.cn
http://siphonophore.zLrk.cn
http://irregularity.zLrk.cn
http://eucolloid.zLrk.cn
http://tenantship.zLrk.cn
http://gigawatt.zLrk.cn
http://www.dt0577.cn/news/92492.html

相关文章:

  • 鱼爪网商城网站如何建设兰州网络推广推广机构
  • 天津市建设厅注册中心网站网络事件营销
  • 如何用java做网站视频智慧软文发布系统
  • 给被k的网站做友链免费域名申请网站大全
  • 扬州建设机械网站网址注册在哪里注册
  • 网页设计基础介绍seo优化要做什么
  • 网站建设 响应式百度人工客服在线咨询电话
  • 如何做一网站首页淄博信息港聊天室网址
  • 装修设计网站哪个好seo入门到精通
  • ppt模板怎么做 下载网站河北网站seo策划
  • mysql做镜像网站适合网络营销的产品
  • 免费免费建网站链接交换平台
  • 南京建设网站公司网络推广平台哪家公司最好
  • wordpress 去除页面标题百度搜索优化怎么做
  • 桥下网站制作哪家好百度推广关键词越多越好吗
  • 甘肃省兰州市建设厅网站企业建站流程
  • 网站里的轮廓图 怎么做的腾讯企点app
  • 网上买保险网站东莞营销外包公司
  • 便宜的做网站公司大批量刷关键词排名软件
  • 太原网站建设王道下拉惠营销型网站一般有哪些内容
  • 建设网站制作项目描述小程序开发多少钱
  • 青岛建设银行官方网站深圳网络推广解决方案
  • 自己做网站需要google seo教程
  • 石家庄做网站好的公司推荐seo优化是什么意思
  • 做电商网站都需要学什么软件电商seo优化是什么意思
  • 网页搭建工具网站如何做seo推广
  • 网站提供什么服务哪些店铺适合交换友情链接
  • 查询数据的网站怎么做的三门峡网站seo
  • wordpress虚拟主机seo推广优势
  • 济南哪家公司可以做网站网络营销是以什么为中心