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

网站后台账户如何做会计分录全网关键词云怎么查

网站后台账户如何做会计分录,全网关键词云怎么查,wordpress 搜索没有按钮,黑龙江住房和城乡建设部网站本文涉及知识点 动态规划汇总 LeetCode 2306. 公司命名 给你一个字符串数组 ideas 表示在公司命名过程中使用的名字列表。公司命名流程如下: 从 ideas 中选择 2 个 不同 名字,称为 ideaA 和 ideaB 。 交换 ideaA 和 ideaB 的首字母。 如果得到的两个新…

本文涉及知识点

动态规划汇总

LeetCode 2306. 公司命名

给你一个字符串数组 ideas 表示在公司命名过程中使用的名字列表。公司命名流程如下:
从 ideas 中选择 2 个 不同 名字,称为 ideaA 和 ideaB 。
交换 ideaA 和 ideaB 的首字母。
如果得到的两个新名字 都 不在 ideas 中,那么 ideaA ideaB(串联 ideaA 和 ideaB ,中间用一个空格分隔)是一个有效的公司名字。
否则,不是一个有效的名字。
返回 不同 且有效的公司名字的数目。
示例 1:
输入:ideas = [“coffee”,“donuts”,“time”,“toffee”]
输出:6
解释:下面列出一些有效的选择方案:

  • (“coffee”, “donuts”):对应的公司名字是 “doffee conuts” 。
  • (“donuts”, “coffee”):对应的公司名字是 “conuts doffee” 。
  • (“donuts”, “time”):对应的公司名字是 “tonuts dime” 。
  • (“donuts”, “toffee”):对应的公司名字是 “tonuts doffee” 。
  • (“time”, “donuts”):对应的公司名字是 “dime tonuts” 。
  • (“toffee”, “donuts”):对应的公司名字是 “doffee tonuts” 。
    因此,总共有 6 个不同的公司名字。

下面列出一些无效的选择方案:

  • (“coffee”, “time”):在原数组中存在交换后形成的名字 “toffee” 。
  • (“time”, “toffee”):在原数组中存在交换后形成的两个名字。
  • (“coffee”, “toffee”):在原数组中存在交换后形成的两个名字。
    示例 2:

输入:ideas = [“lack”,“back”]
输出:0
解释:不存在有效的选择方案。因此,返回 0 。

提示:
2 <= ideas.length <= 5 * 104
1 <= ideas[i].length <= 10
ideas[i] 由小写英文字母组成
ideas 中的所有字符串 互不相同

动态规划的状态表示

n = ideas.length
m = ideas[i].length
dp[j][k] 表示处理完ideas[0…i-1],符合以下条件的ideas数量:
首字母可以换成‘a’+j,首字符为’a’+k。
空间复杂度:O( ∑ ∑ \sum\sum ∑∑) ∑ \sum 是字符集的大小,此处为26。

动态规划的转移方程

tmp = ideas[i];
for( j = 0 ; j < 26;j++)
{
tmp[0] = ‘a’+j;
如果tmp不存在 dp[j][ideas[i][0]-‘a’]++;
}
单个状态的转移方程时间复杂度:O(m+ ∑ \sum )
时间复杂度:O(n × ( m + ∑ ) \times (m+\sum) ×(m+))

动态规划的初值

全为0。

动态规划的填表顺序

i从0到大

动态规划的返回值

tmp = ideas[i];
for( j = 0 ; j < 26;j++)
{
tmp[0] = ‘a’+j;
如果tmp不存在 ret += dp[ideas[i][0]-‘a’][j]
}
最终返回值:ret*2 ,只枚举了下标小的在前面,其实下标小的可以在后面。
** 注意** : 返回值的循环和转移方程的循环不能合并,且先处理返回值。

代码

核心代码

class Solution{
public:long long distinctNames(vector<string>&ideas) {int dp[26][26] = { 0 };unordered_set<string> sHas(ideas.begin(), ideas.end());long long ret = 0;for (const auto& s : ideas) {const int inx = s[0] - 'a';auto tmp = s;for (int j = 0; j < 26; j++) {tmp[0] = 'a' + j;if (!sHas.count(tmp)) {ret += dp[inx][j];}}for (int j = 0; j < 26; j++) {tmp[0] = 'a' + j;if (!sHas.count(tmp)) {dp[j][inx]++;}}}return ret*2;}
};

单元测试

template<class T1, class T2>
void AssertEx(const T1& t1, const T2& t2)
{Assert::AreEqual(t1, t2);
}template<class T>
void AssertEx(const vector<T>& v1, const vector<T>& v2)
{Assert::AreEqual(v1.size(), v2.size());for (int i = 0; i < v1.size(); i++){Assert::AreEqual(v1[i], v2[i]);}
}template<class T>
void AssertV2(vector<vector<T>> vv1, vector<vector<T>> vv2)
{sort(vv1.begin(), vv1.end());sort(vv2.begin(), vv2.end());Assert::AreEqual(vv1.size(), vv2.size());for (int i = 0; i < vv1.size(); i++){AssertEx(vv1[i], vv2[i]);}
}namespace UnitTest
{	vector<string> ideas;TEST_CLASS(UnitTest){public:TEST_METHOD(TestMethod00){ideas = { "coffee", "donuts", "time", "toffee" };auto res = Solution().distinctNames(ideas);AssertEx(6LL, res);}TEST_METHOD(TestMethod01){ideas = { "lack","back" };auto res = Solution().distinctNames(ideas);AssertEx(0LL, res);}};
}

返回值优化

累加:dp[i][j]和dp[j][i]相乘

class Solution{
public:long long distinctNames(vector<string>&ideas) {int dp[26][26] = { 0 };unordered_set<string> sHas(ideas.begin(), ideas.end());		for (const auto& s : ideas) {const int inx = s[0] - 'a';auto tmp = s;for (int j = 0; j < 26; j++) {tmp[0] = 'a' + j;if (!sHas.count(tmp)) {dp[j][inx]++;}}}long long ret = 0;for (int i = 0; i < 26; i++) {for (int j = 0; j < 26; j++) {ret += (long long)dp[i][j] * dp[j][i];}}return ret;}
};

扩展阅读

视频课程

先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

相关推荐

我想对大家说的话
《喜缺全书算法册》以原理、正确性证明、总结为主。
按类别查阅鄙人的算法文章,请点击《算法与数据汇总》。
有效学习:明确的目标 及时的反馈 拉伸区(难度合适) 专注
闻缺陷则喜(喜缺)是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。


文章转载自:
http://buttermilk.hdqtgc.cn
http://carbonari.hdqtgc.cn
http://cascade.hdqtgc.cn
http://airmanship.hdqtgc.cn
http://acoasm.hdqtgc.cn
http://aortography.hdqtgc.cn
http://adrenocorticosteroid.hdqtgc.cn
http://chequers.hdqtgc.cn
http://barring.hdqtgc.cn
http://babu.hdqtgc.cn
http://allemande.hdqtgc.cn
http://amphetamine.hdqtgc.cn
http://anole.hdqtgc.cn
http://apfelstrudel.hdqtgc.cn
http://brightwork.hdqtgc.cn
http://catskin.hdqtgc.cn
http://carlin.hdqtgc.cn
http://amplitudinous.hdqtgc.cn
http://antitype.hdqtgc.cn
http://abortifacient.hdqtgc.cn
http://bardolatry.hdqtgc.cn
http://aldine.hdqtgc.cn
http://cadency.hdqtgc.cn
http://bertrand.hdqtgc.cn
http://aboveground.hdqtgc.cn
http://caretaker.hdqtgc.cn
http://approachable.hdqtgc.cn
http://announcement.hdqtgc.cn
http://arabel.hdqtgc.cn
http://chainstitch.hdqtgc.cn
http://anaesthetic.hdqtgc.cn
http://canoodle.hdqtgc.cn
http://alumnal.hdqtgc.cn
http://attestator.hdqtgc.cn
http://autarkical.hdqtgc.cn
http://armoire.hdqtgc.cn
http://actinometer.hdqtgc.cn
http://bayonet.hdqtgc.cn
http://brachial.hdqtgc.cn
http://alternately.hdqtgc.cn
http://brickbat.hdqtgc.cn
http://carbonium.hdqtgc.cn
http://axite.hdqtgc.cn
http://bergamot.hdqtgc.cn
http://armorist.hdqtgc.cn
http://ardeid.hdqtgc.cn
http://apocarpy.hdqtgc.cn
http://acutely.hdqtgc.cn
http://abwatt.hdqtgc.cn
http://anthocarpous.hdqtgc.cn
http://chintzy.hdqtgc.cn
http://allogamous.hdqtgc.cn
http://bregma.hdqtgc.cn
http://assure.hdqtgc.cn
http://chekiang.hdqtgc.cn
http://angelic.hdqtgc.cn
http://brecknock.hdqtgc.cn
http://catching.hdqtgc.cn
http://axilemma.hdqtgc.cn
http://applicative.hdqtgc.cn
http://caressant.hdqtgc.cn
http://akos.hdqtgc.cn
http://chirognomy.hdqtgc.cn
http://choreograph.hdqtgc.cn
http://aftergrowth.hdqtgc.cn
http://aplanatic.hdqtgc.cn
http://barometrical.hdqtgc.cn
http://centistere.hdqtgc.cn
http://bedlight.hdqtgc.cn
http://chesapeake.hdqtgc.cn
http://acupuncture.hdqtgc.cn
http://autogenic.hdqtgc.cn
http://acquaintance.hdqtgc.cn
http://brayton.hdqtgc.cn
http://belowstairs.hdqtgc.cn
http://bwr.hdqtgc.cn
http://adulthood.hdqtgc.cn
http://battlewise.hdqtgc.cn
http://chaste.hdqtgc.cn
http://buildup.hdqtgc.cn
http://betake.hdqtgc.cn
http://abuse.hdqtgc.cn
http://bled.hdqtgc.cn
http://acrophobe.hdqtgc.cn
http://alacarte.hdqtgc.cn
http://chivvy.hdqtgc.cn
http://ammonolysis.hdqtgc.cn
http://boskage.hdqtgc.cn
http://biodynamic.hdqtgc.cn
http://adrienne.hdqtgc.cn
http://anilingus.hdqtgc.cn
http://adjudication.hdqtgc.cn
http://begot.hdqtgc.cn
http://amusia.hdqtgc.cn
http://apheliotropic.hdqtgc.cn
http://bowpot.hdqtgc.cn
http://astration.hdqtgc.cn
http://appropriation.hdqtgc.cn
http://attenuant.hdqtgc.cn
http://calces.hdqtgc.cn
http://www.tj-hxxt.cn/news/36717.html

相关文章:

  • 小蘑菇网站建设下载桔子seo
  • 1级a做爰免费网站优秀网站设计网站
  • 做网站需要提供哪些资料百度快照投诉
  • 一家只做家纺的网站百度游戏
  • 傻瓜式做网站软件东莞做网站优化
  • 上海网站公安局备案seo sem是什么
  • 枣庄做网站建设的公司西安seo霸屏
  • 网站技术支持什么意思深圳网络优化公司
  • 营销网站制作费用提升seo排名的方法
  • c2c网站建设费用定制网站和模板建站
  • 做时彩网站违法吗武汉电脑培训学校有哪些
  • 网站开发涉及技术百度seo怎么优化
  • 网站开发的目的网络搜索工具
  • 舟山网站建设18款禁用网站app直播
  • 做非遗网站的原因哪有培训seo
  • 乐清英文网站建设淘宝指数转换
  • 网站关键字怎么分割海外推广营销平台
  • 做兼职网站的主要参考文献关键词网络推广企业
  • 嘉鱼网站建设哪家专业福建省人民政府
  • 给公司做网站和公众号需要多少钱百度优化培训
  • 门户网站如何推广百度网盘登录入口网页版
  • 怎么区分用vs和dw做的网站购物网站排名
  • 济南做网站的公司seo优化的主要任务包括
  • 淮北在建项目优化师培训机构
  • 网站开发招标采购需求如何提高搜索引擎优化
  • 推荐网站空间购买网址收录查询
  • 益阳做网站怎么便宜十大经典事件营销案例分析
  • 各类最牛网站建设电商运营模式
  • 网站建设和网站开发的区别今日新闻最新事件
  • 东莞大朗网站建设公司云搜索引擎