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

下载模板网站seo优化技巧

下载模板,网站seo优化技巧,日照做网站建设的公司,营销网站 需求说明书今天,带来哈希表相关算法的讲解。文中不足错漏之处望请斧正! 理论基础点这里 1. 快乐数 分析题意 出题者已经把题意明确告诉我们了: 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1&am…

今天,带来哈希表相关算法的讲解。文中不足错漏之处望请斧正!

理论基础点这里


1. 快乐数

分析题意

出题者已经把题意明确告诉我们了:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

题意转化

怎么理解?

如果我们替换平方和的过程中, 发现当前的数字之前已经出现过, 那我们就陷入了无限循环.

如果没有把题意转化过来, 就会手足无措了.

解决思路

那我们只需要不断重复替换平方和的过程, 再同时判断平方和之前是否出现过:

  • 没出现过: 继续重复替换
  • 出现过: 陷入无限循环, 结束

编程实现

取每位上的数

关于取十进制数上的每位, 可以再谈谈.

如, 要取1234中的每位数.

1234 % 10 = 4 //取到最后一位
1234 /= 10; //去掉最后一位
123  % 10 = 3 //取到倒数第二位
123 /= 10; //去掉最后一位
12 % 10 = 4 //取到倒数第三位
12 /= 10; //去掉最后一位
1 % 10 = 4 //取到倒数第四位
1 /= 10; //去掉最后一位
//最终1234变为0,结束

如果是二进制, 八进制, 只需要mod8即可.

class Solution {
public:// 可能替换的过程可能一直循环:// 如果当前得到的数之前已经得到过, 则会无限循环; 反之不会bool isHappy(int n) {unordered_set<int> appearedNum;while (n != 1) {int sum = getSqureSum(n);// 只要当前的数之前没出现过, 就代表可能这个数能变到1if (appearedNum.find(sum) == appearedNum.end()) {appearedNum.insert(sum);} else { // 反之不可能变到1return false;}n = sum;}return true;}
private:int getSqureSum(int n) {int sum = 0;while (n) {sum += pow(n % 10, 2);n /= 10;}return sum;}
};

2. 两数之和

分析题意

*很好理解, 无需分析.

题意转化

找到 x 和 y, 满足 x + y = target.

解决思路

一层遍历获取 x, 查找nums内是否有这样的 y 满足 y = target - x.

关于查找:

  • for暴力查找 – O(n)
  • 哈希快速查找 – O(1)

查找某个元素在某个集合中是否用过, 这是哈希的绝活; 而且题目要求返回下标. 综合这两点, 我们用 unordered_map, 存储键值对的哈希表.

编程实现

class Solution {
public:// 找到 x 和 y, 满足 x + y = targetvector<int> twoSum(vector<int>& nums, int target) {unordered_map<int, int> numsMap; // <value, index>// 一层遍历获取 x, 查找nums内是否有这样的 y 满足 y = target - xfor (int i = 0; i < nums.size(); ++i) {int x = nums[i];int y = target - x;auto iter = numsMap.find(y);if (iter != numsMap.end()) {int i1 = i;int i2 = iter->first;return {i, iter->second};} else {numsMap.insert(pair<int, int>(nums[i], i));}}return {};}
};

今天的分享就到这里了,感谢您能看到这里。

这里是培根的blog,期待与你共同进步!

http://www.mmbaike.com/news/58537.html

相关文章:

  • 西充县建设路小学网站阿里域名注册官网
  • 怎么用表格做网站百度怎么发布短视频
  • 网站 权限seo下载站
  • 企业应该做几个网站阿里云域名注册
  • 动态网站开发参考资料广告模板
  • iis7搭建网站教程seo教学视频教程
  • 深圳网站建设设计科技有限公司市场营销策略有哪4种
  • 建站之星模块南宁seo团队哪家好
  • 专门做眼镜的国外网站精美软文句子
  • 商城版免费网站制作淘宝一个关键词要刷多久
  • 申请企业邮箱需要什么seo是什么软件
  • 长沙申请域名网站备案低价刷赞网站推广
  • 河南网站建设制作神马站长平台
  • 做网站内链什么意思湖南专业关键词优化服务水平
  • 从事赌博类网站建设的上海网站快速优化排名
  • 前端代码练习网站nba最新消息球员交易
  • 网站产品动效怎么做百度竞价排名费用
  • 找别人做网站需要注意什么seo准
  • 单位门户网站可以做百度百科汽车行业网站建设
  • 宁波网络营销服务googleseo优化
  • 私做网站名电子章北京网优化seo优化公司
  • 盐城网站开发公司电话自媒体平台
  • 网站开发如何共用菜单栏require重庆seo教程
  • wordpress手机不显示图片肇庆seo排名
  • 优秀网站作品附近有没有学电脑培训的
  • 其它类型的定制营销型网站全网营销骗局揭秘
  • 青浦做网站微信群免费推广平台
  • 拍卖网站功能需求文档百度助手app下载
  • 企业网站的形式如何做seo优化
  • 怎么学做网站PHP合肥搜索引擎推广