翻转单词排序


本题来说http://blog.csdn.net/v_JULY_v/article/details/6057286 ,中的第十题。

翻转句子中单词的顺序。
题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。
句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
例如输入“I am a student.”,则输出“student. a am I”。

遇到的几个问题:

1 如何将输入带空格的字符串,保存在一个字符串中。

  c++中如何去做呢?

getline(cin, input , '\n');
  c语言呢
char str1[100];
gets(str1);

gets 会将输入回车换成"\0"

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 , '\n');
	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进行编写一遍。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值