単語の並べ替えを反転


本題ではhttp://blog.csdn.net/v_JULY_v/article/details/6057286 ,の10番目の問題です.
文の単語の順序を反転します.タイトル:英語の文を入力して、文の中の単語の順序を反転しますが、単語内の文字の順序は変わりません.文の単語はスペースで区切られています.簡単にするために、句読点は普通のアルファベットと同じように処理されます.例えば、「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で書きます.