1.求字符串中连续出现最多的字串

pair<string, int> substring(const string& str)
{
int i, j, k, len = str.length(), count, maxcount = ;
string substr;
vector<string> substrs; //存储所有的子字符串
for ( i = ; i < len; ++i)
{
substrs.push_back(str.substr(i, len - i));
} for ( i = ; i < len; ++i)
{
for ( j = i + ; j < len; ++j)
{
count = ;
if (substrs[i].substr(,j-i)==substrs[j].substr(,j-i))
{
++count;
for (k = j + (j - i); k < len; k += j - i)
{
if (substrs[i].substr(, j - i) == substrs[k].substr(, j - i))
{
++count;
}
else
break;
}
if (count>maxcount)
{
maxcount = count;
substr = substrs[i].substr(, j - i);
}
}
}
} return make_pair(substr, maxcount);
}

大致理解,但是有没有更佳的解法呢?

2.求字符串中出现的相同且长度最长的字符串,输出首字符的位置

pair<string, int> substring(const string& str)
{
string substr{""};
int i, j, left, right, len = str.length(); for (i = len - ; i > ; --i)
{
for ( j = ; j < len; ++j)
{
if (j + i < len)
{
left = right = ;
substr = str.substr(j, i); left = str.find(substr);
right = str.rfind(substr); if (left!=right)
{
return make_pair(substr,left);
}
}
else
break;
}
} return make_pair(substr,);
}

从大字符串进行拆分,两边结合搜索比将所有子字符串拆分寻找效率高。

至于调用库函数,是比较方便的选择。

3.重写strstr,且返回朱传忠字符子串位置以后的所有字符

const char* strstr_(const char* src,const char* substr)
{
const char* tmp;
while (*src!='')
{
if (*src==*substr)
{
tmp = substr;
while (*src++==*tmp++)
{
if (*tmp=='\0')
{
return src;
}
}
}
else
*src++;
} return nullptr;
}

注意其中为什么使用tmp代替字串,因为可能会重复比较,所以需要字串的值持续存在。

3.将字符串中的单词进行倒置,标点符号不倒换。“i come from nanjing!”->"nanjing! from come i".

void transfer(char* dst,const char* src)
{
bool sign = false;
int i, j, k, left, right, num = , len = strlen(src); for ( i = ; i <= len ; i++)
{
if (' ' != src[i] && '\0' != src[i]) //排除空格
{
if (sign)
{
right++;
}
else
{
sign = true;
left = right = i;
}
}
else
{
if (sign)
{
sign = false;
dst[len -- i] = src[i];
for ( j = left, k = len--right; j <= right; j++, k++)
{
dst[k] = src[j];
}
left = right = ;
}
else
{
dst[len- - i] = src[i];
}
}
}
}

个人觉得比程序员面试宝典的方法更为简洁,不过其方法较容易操作。后续可以补上程序员面试宝典上的操作。

4.程序员面试宝典上一道填空题,移动字符串内容,将字符串的倒数n个字符移动到字符串前面,仅能在while中填空

void righttransfer(char *str,int n)
{
int i = 0, len = strlen(str);
if (n > len) n = len; while (len - n > 0 || (n = 0) != 0)
{
for (i = 0, str[len] = str[0], ++n; i < len; i++)
str[i] = str[i + 1];
} str[len - n] = '\0';
}

这里面的巧妙之处就在于(n = 0) != 0操作,当字符串移动结束,最后一位'\0'因为移动被字符覆盖了,现在需要重新赋值。

而n已经被修改了,这时候就要重新初始化了,利用||特性,前面为真时直接跳过,此时移动到结尾,len-n为false,则跳到后半部分。

n被赋值为0,即n!=0操作为false,跳出循环,完美。

String相关操作的更多相关文章

  1. 路径打印(set以及字符串的相关操作)

    题目链接 题目描述 给你一串路径,譬如: a\b\c a\d\e b\cst d\ 你把这些路径中蕴含的目录结构给画出来,子目录直接列在父目录下面,并比父目录向右缩一格,就像这样: a   b     ...

  2. redis对string进行的相关操作

    redis对string类型操作的相关命令以及如何在python使用这些命令 redis对string类型操作的命令: 命令 语法 概述 返回值 Redis SET 命令  set key value ...

  3. php对二维数组进行相关操作(排序、转换、去空白等)

    php对二维数组进行相关操作(排序.转换.去空白等) 投稿:lijiao 字体:[增加 减小] 类型:转载 时间:2015-11-04   这篇文章主要介绍了php对二维数组进行相关操作,包括php对 ...

  4. DataTable相关操作,筛选,取前N条数据,获取指定列数据

    DataTable相关操作,筛选,取前N条数据,获取指定列数据2013-03-12 14:50 by Miracle520, 2667 阅读, 0 评论, 收藏, 编辑 1 #region DataT ...

  5. 从零自学Hadoop(24):Impala相关操作上

    阅读目录 序 数据库相关 表相关 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...

  6. JAVA基础5——与String相关的系列(1)

    与String相关的系列 String, 是JAVA中常见的一个引用类型,且其具有一定的特殊性. String类型被设置为final型,即不可继承,也就不可修改其中的实现. String可以改变吗 S ...

  7. 利用JAVA API远程进行HDFS的相关操作

    学习HDFS有一段时间了,现在把自己总结的HDFS的相关操作代码展示给大家. 主要有HDFS的增删改查,文件的追加,windows本地文件的上传,hdfs文件的下载,文件重命名,创建目录,文件是否存在 ...

  8. LayUI之table数据表格获取行、行高亮等相关操作

    前言 目前LayUI数据表格既美观有不乏一些实用功能.基本上表格应有的操作已经具备,LayUI作者[贤心]肯定是煞费苦心去优化,此处致敬.但是实话实话,如果单纯那数据表格功能来说,EasUI的数据表格 ...

  9. Map集合中,关于取值和遍历的相关操作

    这是自己的关于map集合的相关操作的小研究,分享给大家. 主要代码内容包含以下: 1,map集合的遍历 2,根据key值获取value值 3,根据value值获取key值 4,返回最大value值对应 ...

随机推荐

  1. Why doesn't Genymotion run on Windows 10?

    To date, VirtualBox is not yet fully compatible with Windows 10. As Genymotion relies on the use of ...

  2. mybatis获得刚刚插入的自增的值

    转自这里 在http://blog.csdn.net/zhangwenan2010/article/details/7579191   介绍了MyBatis 3 的配置过程, 其中,Product 类 ...

  3. jQuery图片无缝滚动JS代码ul/li结构

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. [Hibernate] - Criteria Select

    使用Hibernate的Criteria做查询. 参考文档: http://docs.jboss.org/hibernate/orm/3.5/reference/zh-CN/html/querycri ...

  5. web开发

    教程 html教程 CSS 教程 JavaScript 教程 参考手册 HTML 4.01 / XHTML 1.0 参考手册 CSS 参考手册 JavaScript 参考手册 PHP 手册 CodeI ...

  6. python-unicode十进制数字转中文

    #coding:utf-8 '''主要是unichr()函数.以下数组中的元素转换后为繁体中文,若不加encode("GB18030")就不能正确显示,而且会报错:('gbk' c ...

  7. LinkedHashMap的实现原理(复习)

    1. LinkedHashMap概述: LinkedHashMap是Map接口的哈希表和链接列表实现,具有可预知的迭代顺序.此实现提供所有可选的映射操作,并允许使用null值和null键.此类不保证映 ...

  8. SharedPreferences实现自动登录记住用户名密码

    最近Android项目需要一个自动登录功能,完成之后,特总结一下,此功能依靠SharedPreferences进行实现.   SharedPreferences简介 SharedPreferences ...

  9. 转-TabHost组件(二)(实现底部菜单导航)

    http://www.cnblogs.com/lichenwei/p/3975095.html 上面文章<安卓开发复习笔记——TabHost组件(一)(实现底部菜单导航)>中提到了利用自定 ...

  10. Visual Stadio 2015创建WebApplication应用和运行赏析

    专题图: 1,创建一个WebApplication应用 2,项目结构和布局  3,运行项目 作者:ylbtech出处:http://ylbtech.cnblogs.com/本文版权归作者和博客园共有, ...