倒着处理的思维--包含字符串匹配和九度1510 替换空格 剑指offer03
2015-08-28 15:08
337 查看
倒着来是处理字符串等的一个不错的技巧。举个例子,和这道题无关的,但是难度和意义都是更好的。
比如非完全匹配,就是差一个字符不匹配
那么其实有一种复杂度还不错的做法:
模式串:aacb
需要匹配的字符串:
1、aamb
2、acb
3、aamdb
这个时候其实可以先正向匹配,算出来匹配的字符的个数p1,再反向匹配,算出来匹配的个数p2,然后看p1+p2与模式串的长度的关系
恩,以上...还没做过具体题目
再看这道题,也是倒着处理字符串的思路:O(n)处理掉
#include <cstdio>
#include <cstring>
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
const int SIZE = 1000000+1;
char str[SIZE];
char ans[SIZE*2];
int leng;
void solve(){
leng = strlen(str);
int blank = 0;
for(int i=0;i<leng;i++){
if(str[i] == ' ')blank++;
}
int ansleng = blank*2+leng;
int oldptr = leng-1;
int newptr = ansleng-1;
ans[ansleng] = '\0';
while(oldptr>=0){
if(str[oldptr] == ' '){
ans[newptr]='0';
ans[--newptr]='2';
ans[--newptr]='%';
}else{
ans[newptr]=str[oldptr];
}
//cout << newptr << " " << oldptr << endl;
--newptr;
--oldptr;
}
printf("%s\n",ans);
}
int main(){
//freopen("03.txt","r",stdin);
while(cin.getline(str,SIZE)){
//cout << str << endl;
solve();
}
return 0;
}
比如非完全匹配,就是差一个字符不匹配
那么其实有一种复杂度还不错的做法:
模式串:aacb
需要匹配的字符串:
1、aamb
2、acb
3、aamdb
这个时候其实可以先正向匹配,算出来匹配的字符的个数p1,再反向匹配,算出来匹配的个数p2,然后看p1+p2与模式串的长度的关系
恩,以上...还没做过具体题目
再看这道题,也是倒着处理字符串的思路:O(n)处理掉
#include <cstdio>
#include <cstring>
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
const int SIZE = 1000000+1;
char str[SIZE];
char ans[SIZE*2];
int leng;
void solve(){
leng = strlen(str);
int blank = 0;
for(int i=0;i<leng;i++){
if(str[i] == ' ')blank++;
}
int ansleng = blank*2+leng;
int oldptr = leng-1;
int newptr = ansleng-1;
ans[ansleng] = '\0';
while(oldptr>=0){
if(str[oldptr] == ' '){
ans[newptr]='0';
ans[--newptr]='2';
ans[--newptr]='%';
}else{
ans[newptr]=str[oldptr];
}
//cout << newptr << " " << oldptr << endl;
--newptr;
--oldptr;
}
printf("%s\n",ans);
}
int main(){
//freopen("03.txt","r",stdin);
while(cin.getline(str,SIZE)){
//cout << str << endl;
solve();
}
return 0;
}
相关文章推荐
- 利用Gulp实现JSDoc 3的文档编写过程中的实时解析和效果预览
- CSS3 用户界面
- ionic+AngularJs项目中实现三级联动效果,筛选省份、城市、区县
- js实现简单折叠、展开菜单的方法
- web前端开发JQuery常用实例代码片段(50个)
- Bootstrap自带的chart插件
- form表单序列化JSON
- [leetcode] 25.Reverse Nodes in k-Group
- 12. jQuery - 获得内容和属性
- JSON语法-对对象的简单定义
- 点击文字链接提交Form表单
- 将EXCEL中的空间数据转换为shape文件和GDB中的feature class
- js实现超简单的展开、折叠目录代码
- CSS3 多列
- hdu 1829 A Bug's Life(并查集)
- JS 中 this上下文对象的使用方式
- jquery的ajax同步和异步
- jade模板引擎学习笔记(WebsStorm9.0.3+ nodejs+express+jade)
- 如何设置像我这样的博客的样式。
- ionic结合HTML5实现打电话功能