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. js中数组Array的一些常用方法总结

    var list = new Array()是我们在js中常常写到的代码,今天就总结一下Array的对象具有哪些方法. list[0] = 0; list[1] = 1; list[2] = 2; 或 ...

  2. 编写使用SpringSecurity的JUnit测试提醒

    近日在使用SpringSecurity的项目中发现一个小问题,就是在接口上加了@Secured标注限制调用接口权限时,某些JUnit无法正常调用了. 例如: @Secured(PrivilegeDAO ...

  3. 按后退键退出Android程序

    主要的目的是按后退键的时候,让程序能够退出. 实现起来的思路: 1.捕获后退键被按了这个事件. Java代码  @Override public boolean onKeyDown(int keyCo ...

  4. mootools里选择器$,$$,$E,$ES等的区别

    区别就是 $和$$都是1个参数, $适用于ID,或者ID代表的对象 $$适用于CSS选择器 $E和$ES,有2个参数,第二个参数是可选参数代表(filter,即某个ID范围里的元素) $E('inpu ...

  5. [原]Fedora 20安装记录

    Fedora是我最喜欢的Linux版本,很长时间以来我都在安装使用.近一年多以来一直在搞一个C#相关的开发,很久都没有接触Fedora了,我上一次使用的版本还是Fedora 17.本以为作为一个“老” ...

  6. lwip:网络数据包读取和解析过程

    1. 程序的某处(poll or interrupt)在有数据可读时调用ethernetif_input,该函数依次调用以下函数: 1.1 low_level_input(),将网络数据读入内存: 1 ...

  7. SqlServer——阻止保存要求重新创建表的更改

    场景: 修改已有数据的列宽时,提示“阻止保存要求重新创建表的更改”. 解决: 工具-〉选项-〉左侧有个 设计器-〉表设计器和数据库设计器 -> 阻止保存要求重新创建表的更改(右侧) 把钩去掉即可 ...

  8. 详解 “Android UI”设计官方教程

    我们曾经给大家一个<MeeGo移动终端设备开发UI设计基础教程>,同时很多朋友都在寻找Android UI开发的教程,我们从Android的官方开发者博客找了一份幻灯片,介绍了一些Andr ...

  9. oracle学习笔记(四)oracle内存优化

    emca -config dbcontrol db -repos recreate 解决'oracle Environment variable ORACLE_SID not defined. Ple ...

  10. CSS图片垂直居中方法

    让div里面的多行文本垂直居中的方法: div{height:100px;width:100px;border:solid 1px red;text-align:center; display:tab ...