#include<iostream>
#include<algorithm>
#include<functional>
using namespace std;
char firstStrAppearOne(const char* str);// 第一个只出现一次的字符
void str1MinusStr2(char* str1,const char* str2);// 删除出现在第二个字符串中的字符
void uniqueStr(char* str);// 删除重复字符
int main()
{
    char* str="aac"; // str指向字符串常量
    cout<<firstStrAppearOne(str)<<endl;
    char str1[]="abcdefghbghc";
    str1MinusStr2(str1,"bce"); // 参数必须是指向可修改内存的指针
    cout<<str1<<endl;
    char str2[]="aaabcdefegghhgi";
   //char str2[]="abcd";
   uniqueStr(str2);
   cout<<str2<<endl;
   return 0;
}
char firstStrAppearOne(const char* str)
{
     if(str==NULL)
         return'\0';
     int hash[256]={0};
     const char* p=str;
     while(*p!='\0')
    {
        ++hash[*p];
        p++;
    }
    while(*str!='\0')
   {
       if(hash[*str]==1)
       return *str;
      ++str;
   }
      return '\0';
}
void str1MinusStr2(char* str1,const char* str2) // 这里的删除字符,是字符前移,后在新的结尾加上\0
{
      if(str1==NULL||str2==NULL)
      return;
      bool hash_flag[256]={0};
      const char* p_str2=str2;
     while(*p_str2!='\0')
    {
         hash_flag[*p_str2]=true;
         ++p_str2;
    }
// 用两个指针实现O(n)的删除移动算法, 关键在于p2的值不能受p1的影响
   char* p1=str1;
   char* p2=str1;

while(*p2!='\0'&&hash_flag[*p2]!=true) // p2的初试值设置为第一个需要删除的结点
    p2++;
   if(*p2=='\0') // 没有需要删除的返回
   return;

char tmp;
   while(*p1!='\0') // p1找到第一个需要删除的点
  {
       while(*p1!='\0'&&hash_flag[*p1]!=true)
       ++p1;
       if(*p1=='\0')
       return;
      else
     {
            while(*p2!='\0'&&hash_flag[*p2]==true) // p2找到后面第一个需要保留的字符
            ++p2;
            if(*p2=='\0')
           {
                 *p1='\0';
                 return;
           }
           else
          {
                 tmp=*p1;
                *p1=*p2;
                *p2=tmp;
           }
     }
     ++p1;
   }
}
void uniqueStr(char* str) // 同上一个算法类似,也是用两个指针
{
        if(str==NULL)
            return;
        bool flag[256]={false}; // 此处如果为true 表示前面出现过,要删除
        char* p1=str;
        char* p2=str;
        while(*p1!='\0') // 为p2设置初始值,指向第一个需要删除的字符
        {
              if(flag[*p1]==false)// 首次出现,相应为置为true
                    flag[*p1]=true;
              else // 第n>2次出现,需要删除
             {
                  p2=p1;
                  break;
              }
             ++p1;
        }
        char tmp;
        while(*p1!='\0') // 此时p1 p2都指向第一个需要删除的字符
        {
              if(flag[*p1]==false)// 首次出现,相应为置为true
                     flag[*p1]=true;
             else // 第n>2次出现,需要删除
             {
                    while(*p2!='\0'&&flag[*p2]==true)
                             ++p2;
                    if(*p2=='\0')
                   {
                        *p1='\0';
                         return;
                   }
                  else
                  {
                        flag[*p2]=true;
                        tmp=*p1;
                       *p1=*p2;
                      *p2=tmp;
                   }
            }
            ++p1;
       }
}

面试35-删除字符串重复字符-删除出现在第二个字符串中的字符-第一个只出现一次的字符-hash表计数的更多相关文章

  1. C++版 - 剑指Offer 面试题35:第一个只出现一次的字符 解题报告(华为OJ034-找出字符串中第一个只出现一次的字符)

    面试题35:第一个只出现一次的字符 题目:在一个字符串中找到第一个只出现一次的字符.如输入abaccdeff,则输出b.(2006年google的一道笔试题.) 分析: 首先应向确认一下是ASCII字 ...

  2. 剑指Offer 找出字符串中第一个只出现一次的字符

    题目描述 找出字符串中第一个只出现一次的字符 如果无此字符 请输出'.' 输入描述: 输入一串字符,由小写字母组成 输出描述: 输出一个字符 输入例子: asdfasdfo 输出例子: o 思路:数组 ...

  3. (剑指Offer)面试题35:第一个只出现一次的字符

    题目: 在字符串中找出第一个只出现1次的字符,如输入“abaccdeff”,则输出b. 思路: 1.暴力遍历 从头开始扫描字符串中的每个字符,当访问某个字符时,取该字符与后面的每个字符相比较,如果没有 ...

  4. 剑指offer35题:第一个只出现一次的字符+剑指offer55题:字符流中第一个不重复的字符+剑指offer51题:数组中重复的数字

    在看剑指offer的时候,感觉这三个题目很像,都是用哈希表可以解决,所以把这三个题整理出来,以供复习. 剑指offer35题:第一个只出现一次的字符 题目描述:在字符串中找出第一个只出现一次的字符.如 ...

  5. 【Java】 剑指offer(50-1) 字符串中第一个只出现一次的字符

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 在字符串中找出第一个只出现一次的字符.如输入"abacc ...

  6. 《剑指offer》第五十题(字符串中第一个只出现一次的字符)

    // 面试题50(一):字符串中第一个只出现一次的字符 // 题目:在字符串中找出第一个只出现一次的字符.如输入"abaccdeff",则输出 // 'b'. #include & ...

  7. 【编程题目】在一个字符串中找到第一个只出现一次的字符。如输入 abaccdeff,则输出 b。

    第 17 题(字符串):题目:在一个字符串中找到第一个只出现一次的字符.如输入 abaccdeff,则输出 b. 思路:此题非常容易. 最开始是想开辟一块空间存储每个字符出现的次数. 但转念一想,似乎 ...

  8. 【剑指offer】面试题35:第一个只出现一次的字符

    题目: 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符的位置.若为空串,返回-1.(书上是要求返回字符) 思路: 第一遍扫描保存下每个字符出现的 ...

  9. 剑指Offer 34. 第一个只出现一次的字符 (字符串)

    题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 题目地址 https:// ...

随机推荐

  1. SWPUCTF2019 | 神奇的二维码

    拖到binwalk里面发现4个压缩包: 查找一下RAR的文件头,然后把它们提取出来: 第一个base64一下得到第二个压缩包的密码: 第二个压缩包可以,emmm,保存一下扩充一下自己的表情包库: 第三 ...

  2. $\LaTeX$数学公式大全8

    $8\ Miscellaneous\ symbols$ $\infty$ \infty $\nabla$ \nabla $\partial$ \partial $\eth$ \eth $\clubsu ...

  3. oracle取出所有表和视图

    select c.TABLE_NAME, d.COMMENTS, d.table_type, (select wmsys.wm_concat(a.column_name) from user_cons ...

  4. finally的一个妙用

    ●传统用法try-catch-finally大家都会用:try包裹可能抛出异常的代码:catch捕获异常并对其处理:finally做一些资源关闭等回收工作.简单明了一句话就能说清. 稍微进阶一些的,大 ...

  5. Bzoj3073Journeys

    这不裸的dij吗?来,弄他. 打完以后发现不妙,这数据范围略神奇……算一算,考一场都可能跑不出来.map去重边(成功额外引入log)不怕,交.TLE,54. 这不玩呢吗,把map去了,交.MLE,71 ...

  6. CentOS7——卡在在启动界面

    系统在启动时,卡在启动界面比如: 解决方法一 这个时候其实系统已经启动了,如果这台机器之前正确配置好了网络连接的话,此时我们可以使用另外一台机器通过SSH来登录这台机器进行修改. 这个时候将系统出问题 ...

  7. 四、SpringBoot出现报错:java.lang.NoSuchMethodError: org.springframework.http.MediaType.equalsTypeAndSubtype(Lorg/springframework/util/MimeType;)Z

    idea启动SpringBoot项目后,出现如下错误: 2019-11-19 15:24:44.344 ERROR 39168 --- [nio-8443-exec-1] o.a.c.c.C.[.[. ...

  8. 在smarty模板中截取指定长度的字符串

    在smarty模板中截取指定长度的字符串,可使用truncate这个插件. 用法: {{$data.value|truncate:28:'...'}} 28个字节14个字数输出,多余部分输出...,一 ...

  9. ubuntu快速联网

    1:打开ubuntu 2:设置 特殊:red hat设置视频:http://www.jikexueyuan.com/course/1349_3.html?ss=1

  10. Python 爬虫的工具列表

    Python 爬虫的工具列表 这个列表包含与网页抓取和数据处理的Python库 网络 通用 urllib -网络库(stdlib). requests -网络库. grab – 网络库(基于pycur ...