字符串的一些关键点
整数与罗马数字的转换
data:image/s3,"s3://crabby-images/7367f/7367f7d3e2dc540ab6729aa633bd41856f133143" alt="Image description"
Click to expand the code
class Solution {
public:
// 通过vector穷举了所有的可能性(由于不同的千百十位对应不同的字符,故此穷举最直接)
vector<pair<int, string>> group = {
{1000, "M"},
{900, "CM"},
{500, "D"},
{400, "CD"},
{100, "C"},
{90, "XC"},
{50, "L"},
{40, "XL"},
{10, "X"},
{9, "IX"},
{5, "V"},
{4, "IV"},
{1, "I"},
};//顺序很重要!
string intToRoman(int num) {
string output_str;
// 遍历这个group
for(int i=0;i<group.size();i++)//长度固定因此复杂度为O(1)
{
// 注意遍历是从大到小减的~
while(num>=group[i].first)//通过while循环,取完了,i再变
{
output_str+=group[i].second;
num=num-group[i].first;
}
if(num==0)
break;
}
return output_str;
}
};
穷举的时候,用map也可以,但是map默认是按key从小到大排列了的,改一下即可~
data:image/s3,"s3://crabby-images/cd9eb/cd9eb3a4330e4838290100b54464699c5d49207e" alt="Image description"
跟上面很类似,只是反过来由罗马变为阿拉伯数字而已~
class Solution {
public:
unordered_map<char, int> define_group=//注意是从小到大
{
{'I',1},
{'V',5},
{'X',10},
{'L',50},
{'C',100},
{'D',500},
{'M',1000}
};
int romanToInt(string s) {
int num_value=0;
for(int i=0;i<s.size();i++)
{
// 若字符串的当前位对应的数字小于下一位对应的数字(对应特殊的4,9等等)
if(define_group[s[i]]<define_group[s[i+1]])
{
//逐个遍历,逐个相加即可~
num_value+=define_group[s[i+1]]-define_group[s[i]];
i=i+1;//当前位和下一位都算了,可以跳过
}
else//反之,则是当前位和下一位相同
num_value+=define_group[s[i]];//直接获取值
}
// num_value=num_value+define_group[s[s.size()-1]];//最后一个加上
return num_value;
}
};
data:image/s3,"s3://crabby-images/46d16/46d167eae2c7f7f4f249ab51680bad74c0145207" alt="Image description"
人民币的转换比罗马数字难多了,主要是还要考虑不同位的念法不一样。此处单纯给出代码,还没理思路~
进制转换
进制转换是非常经典的题目,其实关键点都是十进制与其他进制相互转换而已~
data:image/s3,"s3://crabby-images/0748f/0748ff0a0fc06cddef0ac988f00926e2cd0102f9" alt="Image description"
Click to expand the code。注意16进制就是要乘16次幂(pow(16,n))。输入的为字符串,每次对比是字符'0'和'9'
二进制求和
data:image/s3,"s3://crabby-images/2db0a/2db0acd18a98e3c4d4ba4a5fa933f2d861008b7d" alt="Image description"
要用string来解题才可以,如果先转换为十进制然后相加可能出现越界情况.时间复杂度, O(Max(M,N))
在内存中存储时1个数
data:image/s3,"s3://crabby-images/38b2e/38b2ec58570253630d728af181b4a6848890d93e" alt="Image description"
此题实际上就是转换为二进制
求最大连续bit数
data:image/s3,"s3://crabby-images/6cd4d/6cd4d5c11fc12491c9ca7197816d7236afc80508" alt="Image description"
跟上一题是很像的,主要是要注意设计循环迭代求最值都需要对比一下最后一个
整数与ip地址之间的转换
data:image/s3,"s3://crabby-images/d1719/d17195e6bd2e0ec50d526a0b4d79dd57b47fc27a" alt="Image description"
此题包含了十进制转2进制;2进制转10进制。注意n进制转10进制都是pow(n,第几位)逢n进位,故此满一位就是要乘n。细节的地方主要是分组+0的讨论。
Hash Table相关题目
unordered_map内部的元素是无序的,即插入的顺序和输出的顺序不一定相同。而map内部的元素是有序的,它是按照元素的键值大小进行排序,所以它的内部元素是有序的。
定义
合并表记录
data:image/s3,"s3://crabby-images/39a8f/39a8ff6297a120568e18de94c92436d686e82a84" alt="Image description"
Click to expand the code
简单密码
data:image/s3,"s3://crabby-images/41448/414489e52944f032939f1b22cbef37d7d1de48a9" alt="Image description"
Click to expand the code。关键在于hash table的初始化
称砝码
data:image/s3,"s3://crabby-images/7abfa/7abfacca94db956f1d37a6e8659bb8fd6071f1f0" alt="Image description"
一开始是想着用回溯算法去解的,但是复杂度比较高,且剪枝策略不正确,改为hash table来算吧~
hash table的思维,vector的解法:名字的漂亮度
data:image/s3,"s3://crabby-images/2af12/2af123d2f1052ebee866897d995651ca4a0d388b" alt="Image description"
此题是hash table的思维,但是hash table不好进行排序,因此用vector代替,对应位置each_string[each_char-'a']填入即可实现计数
set与map自动升值排列:整型数组合并
data:image/s3,"s3://crabby-images/542b5/542b5f46fd2d9ffa17e705c0a2e9bf71d264e27d" alt="Image description"
Click to expand the code.两种解法均可~
set通过.count(each_str)来代替find寻值:字符串字符匹配
data:image/s3,"s3://crabby-images/df654/df6547694aec395d64654e849df593f5dc416ae6" alt="Image description"
Click to expand the code
Click to expand the code,第二种解法其实就是换个思路,感觉差不多~
将map转换为vector进行排序:字符统计
data:image/s3,"s3://crabby-images/71eb9/71eb96d52ab17f776fee1a50d7cdbde460f5ad85" alt="Image description"
Click to expand the code
其他string相关的题目
字符串最后一个单词的长度
data:image/s3,"s3://crabby-images/b2343/b23433fb0c8b97cff736239dcaf8469fd1d60b18" alt="Image description"
Click to expand the code,trick:输入为空格的时候就停止输入
计算某字符出现次数
data:image/s3,"s3://crabby-images/93522/935222b9b25ab763d5be13abfe56ac1bd399ce7d" alt="Image description"
注意不区分大小写,需要调用tolower()函数转换成小写。时间复杂度为O(N),空间复杂度为O(1)
下面方法采用hash table,也可以,但是空间复杂度应该是O(N),时间复杂度一样
明明的随机数
data:image/s3,"s3://crabby-images/20f16/20f16f7173d9a43a5c2072d4512d9cd1c02adb7b" alt="Image description"
题目:明明生成了N个1到500之间的随机整数。请你删去其中重复的数字,即相同的数字只保留一个,把其余相同的数去掉,然后再把这些数从小到大排序,按照排好的顺序输出。
Click to expand the code。此题的关键是set的使用
字符串分隔
data:image/s3,"s3://crabby-images/1268a/1268aa7431dcc64506b65bdbe5a5e0f91c0247e8" alt="Image description"
Click to expand the code
提取不重复的整数
data:image/s3,"s3://crabby-images/e0df7/e0df72f3a1c31be523d23dc713fecfc86f5eefae" alt="Image description"
Click to expand the code
string颠倒:数字颠倒
data:image/s3,"s3://crabby-images/93c19/93c197b64873bd91375dbe9350098d7dd3b56d9f" alt="Image description"
Click to expand the code
字符串排序
data:image/s3,"s3://crabby-images/1d461/1d46118fe9b1f4ca42f20dd3741ffbaf007a3c8f" alt="Image description"
Click to expand the code
data:image/s3,"s3://crabby-images/cff6a/cff6a35c4360d1d310542a125efd538b45f5676b" alt="Image description"
这题难度要大很多,关键是构建一个vector,先按字母的顺序存放字母。然后当遇到字母的时候,再次从vector中拿出来(对于同字母的大小写,按输入的顺序进行放入,也按输入的顺序进行取出)。注意通过处理原输入,可以避免处理其他不变的情况
字符串:坐标移动
data:image/s3,"s3://crabby-images/80a5e/80a5e05f814ab3867ac1f61d4914d2f365929fce" alt="Image description"
Click to expand the code
密码验证合格程序
data:image/s3,"s3://crabby-images/83bb4/83bb4ffa2830cd7acdf51b6a3e6ecc111f5fde95" alt="Image description"
Click to expand the code
删除字符串中出现次数最少的字符
data:image/s3,"s3://crabby-images/d7daa/d7daac0c33b297cadeb6e875344b06ea8b94b970" alt="Image description"
Click to expand the code
查找兄弟单词
data:image/s3,"s3://crabby-images/f0693/f0693ce62f6d7074c11f1de74e3273f41c09c524" alt="Image description"
Click to expand the code。时间复杂度:O(nlogm),其中n为单词总数,m为最大单词的长度。logm为排序算法的复杂度。空间复杂度是O(N)注意最后一个单词才是目标,审题最重要!!!
字符串加解密
data:image/s3,"s3://crabby-images/1f69c/1f69c49ffcb788a1beb276a6ae1e8f2e31993197" alt="Image description"
Click to expand the code。注意循环中用else if不然就会一直处理,一直叠加。
字符串反转
data:image/s3,"s3://crabby-images/7a34d/7a34d732dbbec00f91d86960d8070981310c55c4" alt="Image description"
Click to expand the code
字符串相乘
data:image/s3,"s3://crabby-images/70aa6/70aa68e6acd1e455f5a7eff024876c6a6915807f" alt="Image description"
这个解法相对比较直接,就是把乘法的计算过程跟加的过程用代码实现了~
也可以采用下图所示的双指针法的思路解题。时间复杂度为O(n*m),空间复杂度为O(n+m)
data:image/s3,"s3://crabby-images/a2b6e/a2b6eb417a8a53404b6d6d5f82d9c9d2a49c47eb" alt="Image description"
data:image/s3,"s3://crabby-images/44892/448921260c5557fee78c1b70a8e1141b4099740e" alt="Image description"
用python的eval函数求解就无敌简单😱
python求解字符串的四则运算
data:image/s3,"s3://crabby-images/78049/780494abae39a2a6e04f90f8be412d6c3ee959ac" alt="Image description"
此题如果用cpp去解的话有点繁琐,为此改为用python,几句代码即可!
同理,上面字符串相乘也是可以类似的用
data:image/s3,"s3://crabby-images/e50ef/e50ef25a08814e17b9f3a55e61fe0b5428fffad5" alt="Image description"
用python解题,三行代码即可!
高精度整数加法
data:image/s3,"s3://crabby-images/a36e1/a36e13b679456efe320506ac09e7d6decd8af9f9" alt="Image description"
最简单就是采用python解题~
此处也给出cpp的解法,处理好进位以及字符串的反转即可~
蛇形矩阵
data:image/s3,"s3://crabby-images/aa4c0/aa4c03a0cd30b32cbed6c8db6d027660f94f6740" alt="Image description"
Click to expand the code.关键是如何填矩阵的思路~
挑7
data:image/s3,"s3://crabby-images/57d16/57d169dcc2b78926e4fd8cfd29e794e25703b8b7" alt="Image description"
Click to expand the code.
查找两个字符串a,b中的最长公共子串
data:image/s3,"s3://crabby-images/9fa4d/9fa4d702727a2e86dae30771acc94312976e55a1" alt="Image description"
Click to expand the code.关键点是字符串中找子字符串的用法str_2.find(temp_str)!=string::npos
成绩排序
data:image/s3,"s3://crabby-images/420ac/420ac643d8a0df7183da49f40789fb92e048ff9c" alt="Image description"
stable_sort 和 sort的区别在于 前者作排序可以使原来的"相同"的值在序列中的相对位置不变
在字符串中找出连续最长的数字串
data:image/s3,"s3://crabby-images/49db7/49db7a7b78de22e43256c0e16c97cb08e3db80c3" alt="Image description"
Click to expand the code
自守数
data:image/s3,"s3://crabby-images/3544c/3544ccabbd0d9bf76f879248d0604ebe32baf035" alt="Image description"
Click to expand the code