【ARTS】01_12_左耳听风-20190128~20190203
ARTS:
- Algrothm: leetcode算法题目
- Review: 阅读并且点评一篇英文技术文章
- Tip/Techni: 学习一个技术技巧
- Share: 分享一篇有观点和思考的技术文章
Algorithm
【leetcode】824. Goat Latin
https://leetcode.com/problems/goat-latin/
1)problem
S给出一个句子,由用空格分隔的单词组成。每个单词只包含小写字母和大写字母。
我们想将句子转换成“ 山羊拉丁语” (一种类似于拉丁语的化妆语言)。
山羊拉丁文规则如下:
- 如果一个单词以元音开头(a,e,i,o或u),则追加"ma" 到单词的末尾。
例如,'apple'这个词变成'applema'。
- 如果一个词以辅音开头(即不是元音),删除第一个字母并将其附加到最后,然后添加"ma"。
例如,这个词"goat" 变成了"oatgma"。
- 'a' 在每个单词的末尾添加一个字母,每个单词的索引在句子中,从1开始。
例如,第一个单词被"a"添加到结尾,第二个单词被"aa"添加到结尾,依此类推。
返回代表从S Goat Latin 转换成的最后一句。
返回代表从S Goat Latin 转换成的最后一句。
Example 1:
Input: "I speak Goat Latin"
Output: "Imaa peaksmaaa oatGmaaaa atinLmaaaaa"
Example 2:
Input: "The quick brown fox jumped over the lazy dog"
Output: "heTmaa uickqmaaa rownbmaaaa oxfmaaaaa umpedjmaaaaaa overmaaaaaaa hetmaaaaaaaa azylmaaaaaaaaa ogdmaaaaaaaaaa"
2)answer
1.用unordered_set判断单词开头是不是元音。
2.一边找完整的单词,一边对单词里的字母进行换位置操作。时间复杂度只需要线性。
3.把末尾要添加的字母直接做成一个字符串,每次循环改一下即可。
4.S增加了词末字符串之后i的下标所指的位置会改变。
3)solution
#include "pch.h"
#include <iostream>
#include <string>
#include <vector>
#include <unordered_set>
#include <algorithm>
using std::vector;
using std::string;
using std::unordered_set;
class Solution {
public:
string toGoatLatin(string S) {
unordered_set<char> vowel = { 'a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U' };
int i = 0;
string sub;
sub = "maa";
// 遍历输入的字符串长度
while (i < S.length())
{
int j = i + 1; // 单词的首位
int isvowel = vowel.count(S[i]); //如果找到值等于k的元素,则返回1,否则返回0。
char tmp = S[i]; // 存储单词的首个字符
while ((S[j] != ' ') && (j < S.length())) // 每个单词内的处理,如果字符不是空格以及没有超过字符串的总长度
{
if (!isvowel) { S[j - 1] = S[j]; } // 如果以辅音(即不是元音)开头,就把第二位的值变成第一位的值,字符串左移
j++;
}
if (!isvowel) S[j - 1] = tmp; // 把以辅音(即不是元音)开头的第一位放到单词末尾
S.insert(j, sub); // 这个单词后插入maa
i = j + sub.length() + 1; // 计算新插入的字符数目
sub = sub + 'a'; // 按照单词个数,依次加a,第一个单词加maa,那么第二次就应该是maaa
}
return S;
}
};
int main()
{
Solution solution;
string str = "The quick brown fox jumped over the lazy dog";
string ret = solution.toGoatLatin(str);
}
Review
【漏洞挖掘】Sleeping stored Google XSS Awakens a $5000 Bounty
1)场景
找Google漏洞
2)问题难点
找Google的存储型XSS漏洞
3)解决问题的方法
Google云提供60天 免费试用
"><img src=x onerror=javascript:alert(1);> …
4)方法细节
[BugBounty] Sleeping stored Google XSS Awakens a $5000 Bounty
https://www.cnblogs.com/17bdw/p/10372402.html
Tip
【安全开发】MFC的CEdit使用(Edit Control控件)
1)场景
MFC-开发小工具
2)问题难点
CEdit使用(Edit Control控件)
3)解决思路
- 编辑框只读
属性 Read Only等于 True,就有了只读效果
- 密码框
属性 Password 等于 True,就有了密码效果
4)方法细节
CEdit使用(Edit Control控件)
https://www.cnblogs.com/17bdw/p/10350818.html
Share
【业务】应急响应工具开发-C++获取当前所有进程的完整路径
1)场景
C++获取当前所有进程的完整路径
2)问题难点
遍历进程,获取进程的完整路径
3)解决思路
CreateToolhelp32Snapshot()
Process32First()
OpenProcess()
GetProcessImageFileName()
GetLogicalDriveStrings()
QueryDosDevice()
4)方法细节
C++获取当前所有进程的完整路径
https://www.cnblogs.com/17bdw/p/10355793.html
【ARTS】01_12_左耳听风-20190128~20190203的更多相关文章
- 【ARTS】01_21_左耳听风-201900401~201900407
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_20_左耳听风-20190325~20190331
zz## ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 ...
- 【ARTS】01_19_左耳听风-20190318~20190324
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_18_左耳听风-20190311~20190317
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_17_左耳听风-20190304~20190310
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_16_左耳听风-20190225~20190303
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_14_左耳听风-20190211~20190217
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_10_左耳听风-20190114~20190120
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_09_左耳听风-20190107~20190113
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
随机推荐
- HSQL可视化工具
本地使用HSQL数据库进行开发,多是集成在开发工具的内部,比如studio,往往看不到HSQL数据库,那么如何查看HSQL数据库呢? 可以使用hsql自带的可视化工具,运行hsqldb-*.jar 包 ...
- Java微信公众号安全模式消息解密
这篇文章主要为大家详细介绍了Java微信公众号安全模式消息解密,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 1.微信公众平台下载解密工具,导入项目中,根据demo解密消息 public stat ...
- 自学Python1.6-Centos内英文语法切换
自学Python之路 自学Python1.6-Centos内中英文语法切换 测试采用是官方Centos7.0系统 1.添加中文输入法 打开设置---区域和语言--->在输入源最下面有一个 + 号 ...
- 【51NOD 1847】奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数)
[51NOD 1847]奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数) 题面 51NOD \[\sum_{i=1}^n\sum_{j=1}^nsgcd(i,j)^k\] 其中\( ...
- 【BZOJ2427】[HAOI2010]软件安装(动态规划,Tarjan)
[BZOJ2427][HAOI2010]软件安装(动态规划,Tarjan) 题面 BZOJ 洛谷 题解 看到这类题目就应该要意识到依赖关系显然是可以成环的. 注意到这样一个性质,依赖关系最多只有一个, ...
- 【poj2396】 Budget
http://poj.org/problem?id=2396 (题目链接) 题意 给出一个矩阵,给出每一行每一列的和,以及若干限制条件,限制了其中每一个元素的上下界,求一种可行的方案使得每一行每一列数 ...
- Luogu 2540 斗地主增强版(搜索,动态规划)
Luogu 2540 斗地主增强版(搜索,动态规划) Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游 ...
- 《CSS揭秘》笔记(一)
前言 我们在现代 CSS 中所面临的挑战已经不在于如何绕过这些转瞬即逝的浏览器 bug.如今的挑战是,在保证 DRY ① .可维护.灵活性.轻量级并且尽可能符合标准的前提下,把我们手中的这些CSS特性 ...
- zoj3707(Calculate Prime S)解题报告
1.计算(a/b)%c,其中b能整除a 设a=b*r=(bc)*s+b*t 则(b*t)为a除以bc的余数 r=c*s+t 而 (a/b)%c=r%c=t (a%bc)/b=(b*t)/b=t 所以对 ...
- vs2013配置opencv2.4.13
此方法配置简单,方便易行,解压opencv2.4.13后得到opencv文件夹,进行如下步骤: 1.添加环境变量 用户变量,新建,变量名opencv,值D:\opencv\build 系统变量,Pat ...