zoukankan      html  css  js  c++  java
  • 面试的基础_01字符串反向操作


    一 字符串中的字节逆转(this is a student ==> tneduts a si siht)
    /************************************************************************* 
        > File Name: testStringByte.h
        > Author: qiaozp 
        > Mail: qiaozongpeng@163.com 
        > Created Time: 2014-9-30 11:21:15
        > Attention: this is a student ===> tneduts a si siht
     ************************************************************************/ 
    #include <iostream>
    #include <string.h>
    using namespace std;
    
    void reverseByByte(char* p, char* e)
    {
        //方法就是按位赋值到目的字符串
        int i = 0;
        int size = strlen(p);
        e[size] = '';
        while((--size) >= 0)
        {
            e[i++] = p[size];
        }
    }
    
    int main()
    {
        char* p = "you are a student!";
        char e[20] = {0};
        reverseByByte(p, e);
        cout << e << endl;
    }



    二 字符串按单词反转(this is a student ==> student a is this)

    /************************************************************************* 
        > File Name: testStringWord.h
        > Author: qiaozp 
        > Mail: qiaozongpeng@163.com 
        > Created Time: 2014-9-30 11:21:15
        > Attention: this is a student ===> student a is this
    ************************************************************************/ 
    #include <iostream>
    #include <string.h>
    using namespace std;
    
    void reverseByWord(char* p, char* e)
    {
        //方法就是记录每一个整的单词的開始和结束位置,然后复制到目标字符串
        int len = strlen(p);
        int end = len;
        int start = 0;
        memset(e, 0, len);
    
        while(len > 0)
        {
            end = len;
            while ((p[len - 1] != ' ') && (len > 0))
            {
                --len;
            };
            start = len--;
            strncpy(e + strlen(e), p + start, end - start);
            e[strlen(e)] = ' ';
    
        }
        e[strlen(e) - 1] = '';      //多出一个空格  谢谢二楼的提醒 
    }
    
    int main()
    {
        char* p = "you are a student!";
        char e[20] = {0};
        reverseByWord(p, e);
        cout << e << endl;
    }











    版权声明:本文博主原创文章。博客,未经同意不得转载。

  • 相关阅读:
    linq语法2 GLenn
    sql 拼接字符串 GLenn
    每日算法 20130225 GLenn
    linq语法1 GLenn
    每日算法 20130227 GLenn
    每日算法 20130226 GLenn
    jquery ajax 分页 GLenn
    PhoneGap应用开发对策:如何通过苹果审核?
    Xcode 4.1/4.2/4.3/4.4/4.5 + iOS 5.1.1免证书(iDP)开发+真机调试+生成IPA全攻略
    rails 散乱记录
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4884198.html
Copyright © 2011-2022 走看看