hihocoder 1485:hiho字符串

描述

如果一个字符串恰好包含2个'h'、1个'i'和1个'o',我们就称这个字符串是hiho字符串。

例如"oihateher"、"hugeinputhugeoutput"都是hiho字符串。

现在给定一个只包含小写字母的字符串S,小Hi想知道S的所有子串中,最短的hiho字符串是哪个。

输入

字符串S

对于80%的数据,S的长度不超过1000

对于100%的数据,S的长度不超过100000

输出

找到S的所有子串中,最短的hiho字符串是哪个,输出该子串的长度。如果S的子串中没有hiho字符串,输出-1。

样例输入

happyhahaiohell

样例输出

5

算法分析:

声明一个 char str[100001] 字符数组,用 cin.getline(str,100001) 来获取每一行的输入字符串。声明 char* ph1,*ph2,*pi,*po 指针,并初始化为0,用来记录 str 字符串中 h、i、o 字符出现的位置。当出现 i 字符时,要判断前面是否出现过 i 字符,如果出现过(用 if(pi!=0) 来判断),则在 前一个 i 出现的位置之前出现的 h 和 o 都要被舍弃掉了(因为我们要找的字符串中只能有2个 h,1个 i ,1个 o);同样的道理适用于字符 o。对于字符 h ,情况略微不同。当出现字符 h 时,要判断 if(ph1!=0),如果为真,则在 h1 之前出现的 i 和 o 都要舍弃掉。 每当 h1,h2,i,o 都齐备的时候,我们就统计一下当前选取的字段的长度,如果小于已经记录的长度,则更新已经记录的长度。最后判断记录的长度值是否为初始化时设置的最大值(least=0X7FFFFFFF):如果是,说明str中没有hiho字符串,返回-1;否则返回记录的长度值。

C++算法实现:

  1. #include<iostream>
  2. using namespace std;
  3. char* ph1 = 0, *ph2 = 0, *pi = 0, *po = 0;
  4. int getCount(char str[]);
  5. int getLen();
  6. int main(int argc, char* argv[])
  7. {
  8. char str[100001];
  9. while (cin.getline(str, 100001)) {
  10. cout << getCount(str) << endl;
  11. }
  12. return 0;
  13. }
  14. int getCount(char str[])
  15. {
  16. char* cur = str;
  17. ph1 = ph2 = pi = po = 0;
  18. int least = 0x7FFFFFFF;
  19. int tmp = 0x7FFFFFFF;
  20. int occur = 0;//遇到了 'h','i','o'中的任何一个
  21. while (*cur != '\0') {
  22. occur = 1;
  23. switch (*cur) {
  24. case 'h':
  25. if (ph1 != 0) {
  26. //在前一个 h 之前出现的 i 和 o 都不可用了
  27. if (pi < ph1) {
  28. pi = 0;
  29. occur = 0;
  30. }
  31. if (po < ph1) {
  32. ph1 = 0;
  33. occur = 0;
  34. }
  35. }
  36. ph1 = ph2;
  37. ph2 = cur;
  38. break;
  39. case 'i':
  40. if (pi != 0) {
  41. //在前一个 i 之前出现的 h 和 o 都不可用了
  42. if (ph1 < pi) {
  43. ph1 = 0;
  44. occur = 0;
  45. }
  46. if (ph2 < pi) {
  47. ph2 = 0;
  48. }
  49. if (po < pi) {
  50. po = 0;
  51. occur = 0;
  52. }
  53. }
  54. pi = cur;
  55. break;
  56. case 'o':
  57. if (po != 0) {
  58. //在前一个 o 之前出现的 h 和 i 都不可用了
  59. if (ph1 < po) {
  60. ph1 = 0;
  61. occur = 0;
  62. }
  63. if (ph2 < po) {
  64. ph2 = 0;
  65. }
  66. if (pi < po) {
  67. pi = 0;
  68. occur = 0;
  69. }
  70. }
  71. po = cur;
  72. break;
  73. default:
  74. occur = 0;//没有发生有效变化
  75. break;
  76. }
  77. if (occur) {//发生了有效变化
  78. tmp = getLen();
  79. if (tmp < least) {
  80. least = tmp;
  81. }
  82. }
  83. cur++;
  84. }
  85. if (least == 0x7FFFFFFF) {//没有 hiho 字符串出现
  86. return -1;
  87. }
  88. return least;
  89. }
  90. int getLen()
  91. {
  92. if (ph1 != 0 && pi != 0 && po != 0) {
  93. char* begin = ph1 < pi ? ph1 : pi;
  94. char* end = ph2 < pi ? pi : ph2;
  95. begin = begin < po ? begin : po;
  96. end = end < po ? po : end;
  97. return end - begin + 1;
  98. }
  99. return 0x7FFFFFFF;
  100. }

hihocoder 1485----hiho字符串的更多相关文章

  1. hiho #1485 : hiho字符串(滑动窗口)

    #1485 : hiho字符串 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 如果一个字符串恰好包含2个'h'.1个'i'和1个'o',我们就称这个字符串是hiho字符 ...

  2. hihocoder 1680 hiho字符串2 dp求方案数+递归

    我们定义第一代hiho字符串是"hiho". 第N代hiho字符串是由第N-1代hiho字符串变化得到,规则是: h -> hio i -> hi o -> ho ...

  3. hihoCoder #1320 : 压缩字符串 区间dp

    /** 题目:hihoCoder #1320 : 压缩字符串 链接:https://hihocoder.com/problemset/problem/1320 描述 小Hi希望压缩一个只包含大写字母' ...

  4. 字符串----hiho字符串(尺取法)

    注意:这道题的解法和最短摘要一样,都是采用尺取法解决问题,注意这儿题目要求恰好包含,也就是说这个hiho字符串必须包含2个'h'.1个'i'和1个'o'.一个不能多,一个也不能少. import ja ...

  5. hihocoder 1320 - 压缩字符串 - [hiho一下160周]

    这道题目可以说是一道非常好非常一颗赛艇的DP题了. 需要注意的是,其中情形3),字符串必然能完全转化为 N(str)形式,如果有N(str1)M(str2)等等另外样式,应该首先使用拼接形式对其进行划 ...

  6. hihocoder offer收割编程练习赛11 A hiho字符串

    思路: 我用的尺取. 注意题目描述为恰好2个'h',1个'i',1个'o'. 实现: #include <iostream> #include <cstdio> #includ ...

  7. hihocoder 1829 - 压缩字符串 - [状压+暴力枚举][2018ICPC北京网络预赛B题]

    题目链接:https://hihocoder.com/problemset/problem/1829 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 Lara Croft, ...

  8. HihoCoder - 1801 :剪切字符串 (置换与逆序对)

    Sample Input 6 5 11 Sample Output 6 小Hi有一个长度为N的字符串,这个字符串每个位置上的字符两两不同.现在小Hi可以进行一种剪切操作: 选择任意一段连续的K个字符, ...

  9. hihocoder -1283 hiho密码(水题)

      时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho根据最近在密码学课上学习到的知识,开发出了一款hiho密码,这款密码的秘钥是这样生成的:对于一种有N个字母的语言 ...

  10. hihocoder #1052 : 基因工程(字符串处理 + 找规律 )

    #1052 : 基因工程 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho正在进行一项基因工程实验.他们要修改一段长度为N的DNA序列,使得这段DNA上最前面 ...

随机推荐

  1. Nginx基本入门

    转自:http://blog.csdn.net/u012486840/article/details/53098890 1.静态HTTP服务器 首先,Nginx是一个HTTP服务器,可以将服务器上的静 ...

  2. Numpy 数组的切片操作

    实例+解释如下(表格):关键是要明白python中数组的下标体系.一套从左往右,一套从右往左. 1 import numpy as np 2 import sys 3 4 def main(): 5 ...

  3. (转)Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)

    原文:https://www.cnblogs.com/chenwolong/p/reduce.html 函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数 ...

  4. Java之IO(九)其它字节流

    转载请注明源出处:http://www.cnblogs.com/lighten/p/7063161.html 1.前言 之前的章节已经介绍了java的io包中所有成对(输入.输出对应)的字节流,本章介 ...

  5. python中的sort方法

    Python中的sort()方法用于数组排序,本文以实例形式对此加以详细说明: 一.基本形式 列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不 ...

  6. Etcd安全配置之Basic Auth认证

    <中小团队落地配置中心详解>文章中我们介绍了如何基于Etcd+Confd构建配置中心,最后提到Etcd的安全问题时说了可以使用账号密码认证以达到安全访问的目的,究竟该如何开启认证以及怎么设 ...

  7. Leetcode 762. Prime Number of Set Bits in Binary Representation

    思路:动态规划.注意1024*1024>10^6,所以质素范围是(0,23). class Solution { public int countPrimeSetBits(int L, int ...

  8. 【.Net】水晶报表CrystalReport粗浅入门

    VB6代码大概是这样的: crystalreport1.Connect:='dsn=xxx;uid=yyy;pwd=zzz;dsq=aaa'; crystalreport1.DiscardSavedD ...

  9. Android Studio 打包生成 APK

    1. 第一步 Build -> Generate Signed APK 2. 之后会要求开发者输入相关的密钥文件和密码 如果有则找到对应的 .jks 文件输入密码完成相应操作,否则则创建一个对应 ...

  10. 2019.2.1 现有vue-cli项目引入ESLint

    ESLint 不管是多人合作还是个人项目,代码规范是很重要的.这样做不仅可以很大程度地避免基本语法错误,也保证了代码的可读性. 可能在早期建立项目的时候,因为一些原因没有引入eslint.单元测试等, ...