zoukankan      html  css  js  c++  java
  • 删除一个字符串中重复出现的字符

    算法思想:以''结束标志,遍历字符串元素surchr,让每个字符与输出output字符串每个元素做比较。一旦output中

    最后一个元素与chr不等,output增加元素,否则,中间就用break跳出,开始判断下一个surchr

    /***************1***************/
    #include <iostream>
    #include <string>
    using namespace std;
    int GetResult(const char* input, char* output);
    int main()
    {
    string str;
    getline(cin, str);
    cout << str<<endl;
    int len = str.length();
    char* output = new char[len + 1];
    if (output == NULL)
    {
    cout<<"heap allocator failed"<<endl;
    return 0;
    }
    memset(output, 0, len+1);
    int ret = 0;
    ret = GetResult(str.c_str(), output);
    for (int k=0; k<ret; k++)
    {
    cout<<output[k];
    }

    cout <<endl;
    return 0;
    }
    int GetResult(const char* input, char* output)
    {
    if (input == NULL || output == NULL)
    {
    return 0;
    }
    const char* surStr = input;
    output[0] = surStr[0];
    int index = 1;
    surStr++;
    while(*surStr != '')
    {
    for (unsigned int i=0; i<strlen(output); i++)
    {
    if (*surStr == output[i])
    {
    break;
    }
    ////output的最后一个非''字符与*surStr不同时执行
    if (i == strlen(output) - 1)
    {
    ++index;
    output[++i] = *surStr;
    }
    }
    surStr++;
    }
    return index ;
    }

    博客内容只为本人学习所感转载亦或自写,不足或错误之处请大家不吝赐教
  • 相关阅读:
    静态INCLUDE与动态INCLUDE的区别
    SQL注入
    SpringMVC
    设计模式—七大原则
    Demo小细节-2
    Java运算符
    Java内部类的基本解析
    接口类和抽象类
    Statement和PreparedStatement
    ArrayList,LinkedLIst,HashMap
  • 原文地址:https://www.cnblogs.com/niupan369/p/4465418.html
Copyright © 2011-2022 走看看