逆序字符串

1 将输入的字符串进行逆序输出

输入一个字符串,然后把这个字符串逆转输出。
如:

  • 输入:123456789
  • 输出:987654321
#include <iostream>
#include <Windows.h>
#include <string>

using namespace std;

int main(void) {
	string str;
	int i;
	int j;
	char tmp;

	cout << "请输入一个字符串: " << endl;
	cin >> str;

	i=0; 
	j = str.length() - 1;
	while (i < j) {
		tmp = str[i];
		str[i] = str[j];
		str[j] = tmp;
		i++;
		j--;
	}

	cout << str << endl;

	system("pause");
	return 0;
}

2 将输入的英文句子以英文单词为单位进行逆序输出

输入一句话,然后把这个字符串以单词为单位,逆转输出。比如将“Alice call Jack”转换为“Jack call Alice”。

思路分析:

方式一:

  1. 首先将每个单词进行逆序,“ecilA llac kcaJ”。
  2. 然后再将整个句子进行逆序,“Jack call Alice”。

方式二:

  1. 首先将整个句子进行逆序,“ecilA llac kcaJ”。
  2. 然后再将每个单词进行逆序,“Jack call Alice”。

下面以第一种方式进行实现:

#include <Windows.h>
#include <string>
#include <iostream>

using namespace std;

int main(void) {
	char str[256] = { 0 };
	int i = 0, j = 0;

	cout << "请输入一句英文:";
	gets_s(str, sizeof(str));

	while (str[i])
	{
		/* 首先跳过前面的空格 */
		while (str[i] == ' ')
		{
			i++;
		}

		j = i;
		/* 找到一个完整的单词 */
		while (str[j] && (str[j] != ' '))
		{
			j++;
		}

		/* 将找到的单词进行逆转 */
		for (int k1 = i, k2 = j - 1; k1 < k2; k1++, k2--)
		{
			char tmp = str[k1];
			str[k1] = str[k2];
			str[k2] = tmp;
		}

		i = j;
	}

	/* 再将全部字符进行翻转即可得到最终结果 */
	for (int k1 = 0, k2 = i - 1; k1 < k2; k1++, k2--)
	{
		char tmp = str[k1];
		str[k1] = str[k2];
		str[k2] = tmp;
	}

	cout << str << endl;

	system("pause");
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值