逆序字符串

部署运行你感兴趣的模型镜像

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;
}

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值