Chinaunix

标题: 求教:一个有关string的小程序。 [打印本页]

作者: poke006    时间: 2009-09-15 17:03
标题: 求教:一个有关string的小程序。
#include <string>                                       
#include <cstddef>                                      
#include <iostream>                                    
#include <cstdlib>                                      
#include <cassert>                                      
using namespace std;                                    

const string& ReverseStrOrder(string& s) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for(size_t i = 0; i < s.size() / 2; i++) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;char p;                          
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p = s.at(s.size() - i - 1);      
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;s.at(s.size() - i - 1) = s.at(i);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;s.at(i) = p;                     
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}                                         
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return s;                                 
}                                                

int main(int argc, char* argv[]) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string s(argv[1]);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cout << s << endl;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cout << ReverseStrOrder(s) << endl;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;assert(s == ReverseStrOrder(s));
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if(s == ReverseStrOrder(s))
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cout << "It is a Palindrome." << endl;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;else
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cout << "It is not a Palindrome." << endl;
}


不知哪里错了,输出总有问题,望大侠指教。
作者: poke006    时间: 2009-09-15 17:53
我顶!!!!!!!!!!!!!!!!
作者: drog1983    时间: 2009-09-15 18:23
首先,有问题就把问题说出来啊,比如你所谓的错误的输出,不能让人猜吧

其次,把C++写成C的模式,为了实现自定义的C++ reverse 方法?

#include <string>
#include <iostream>
#include <algorithm>
using namespace std;

int main(int argc, char *argv[])
{
        string s(argv[1]);

        cout << "original: " << s << endl;
        reverse(s.begin(), s.end());
        cout << "reverse: " << s << endl;

        return 0;
}

作者: poke006    时间: 2009-09-15 18:32
标题: 回复 #3 drog1983 的帖子
最近在看Thinking In C++,我是在做它后面的习题。所以算法那里就不考虑了。
至于输出的话,你一看main(),就应该知道我要的是什么输出了。
作者: justin12zhu    时间: 2009-09-15 18:33
ReverseStrOrder 返回的是s的引用,它肯定会改变原来字符串s的,所以无论每次s和倒过来之后的s都是相等的
作者: poke006    时间: 2009-09-15 18:35
标题: 回复 #5 justin12zhu 的帖子
知道了,正解。谢谢!




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2