単語の並べ替えを反転
本題ではhttp://blog.csdn.net/v_JULY_v/article/details/6057286 ,の10番目の問題です.
文の単語の順序を反転します.タイトル:英語の文を入力して、文の中の単語の順序を反転しますが、単語内の文字の順序は変わりません.文の単語はスペースで区切られています.簡単にするために、句読点は普通のアルファベットと同じように処理されます.例えば、「I am a student.」と入力すると、「student.a am I」が出力される.
いくつかの問題が発生しました.
1入力スペースのある文字列を1つの文字列に保存する方法.
c++ではどうすればいいですか?
getsは入力リターンを「0」に変更します
2ソートを完了する方法.
本稿ではまず,2回反転する比較的従来の方法を紹介する.
まず文字列全体を反転し、「.tneduts a ma I」を得て、各文字列を反転します.「.tneduts」を例に「student.」を得る
3その後、他のアイデアを書き、javaで書きます.
文の単語の順序を反転します.タイトル:英語の文を入力して、文の中の単語の順序を反転しますが、単語内の文字の順序は変わりません.文の単語はスペースで区切られています.簡単にするために、句読点は普通のアルファベットと同じように処理されます.例えば、「I am a student.」と入力すると、「student.a am I」が出力される.
いくつかの問題が発生しました.
1入力スペースのある文字列を1つの文字列に保存する方法.
c++ではどうすればいいですか?
getline(cin, input , '
');
c言語は?char str1[100];
gets(str1);
getsは入力リターンを「0」に変更します
2ソートを完了する方法.
本稿ではまず,2回反転する比較的従来の方法を紹介する.
まず文字列全体を反転し、「.tneduts a ma I」を得て、各文字列を反転します.「.tneduts」を例に「student.」を得る
#include <iostream>
#include <string>
using namespace std;
int revert(char* str, int length)
{
int i = 0;
while( i< length/2)
{
char tmp = str[i];
str[i] = str[length - 1-i];
str[length -1 -i] = tmp;
i++;
}
}
int main()
{
string input;
getline(cin, input , '
');
int length = input.length();
char *in = &input[0];
revert(in, length);
for(int start = 0,end = 0; end <= length+1 ;end++)
{
in = &input[start];
if( input[end] == ' ' || input[end] == '\0')
{
revert(in, end-start);
start = end+1;
}
}
cout <<input<<endl;
}
3その後、他のアイデアを書き、javaで書きます.