- 只有比别人更早、更勤奋地努力,才能尝到成功的滋味
题目:写一个函数,将字符串翻转,翻转方式如下:“I am a student”反转成“student a am I”,不借助任何库函数
,要求单词内字符的顺序不变,句子中单词以空格符隔开。
思路:先反转整个字符串,然后再反转字串。譬如先将“I am a student”反转为“tneduts a ma I”,然后再对每个字串(空格分割)反转一次。
代码(c++):
#include<iostream>
#include<string>
#include <algorithm>
using namespace std;
int main()
{
string str;
while(getline(cin,str))
{
int len = str.length();
reverse(str.begin(),str.end());
int from = 0;
int i=0;
int to;
while(i<len) //之前此处写得是while(str[i]),会有数组越界的可能
{
if(str[i]!=' ')
{
from = i;
while(i<len&&str[i]!=' ')
{
i++;
}
to = i;
reverse(str.begin()+from,str.begin()+to);//这句一定要放在if内部,之前做一个笔试题目,老是出错,后来才发现是这里的问题
}
i++;
}
cout<<str<<endl;
}
return 0;
}代码(c):
#include <stdio.h>
#include <stdlib.h>
void ReverseString(char *s,int from,int to)
{
char t;
while(from<to)
{
t=s[from];
s[from++]=s[to];
s[to--]=t;
}
}
int main()
{
char str[100];
int l,i,from,to;
printf("Enter a String: ");
gets(str);
l=strlen(str);
ReverseString(str,0,l-1);
printf("\n总体翻转:%s\n",str);
i=0;
while(str[i])
{
if(str[i]!=' ')
{
from=i;
while(str[i]&&str[i]!=' ')
{
i++;
}
i=i-1;
to=i;
}
char t;
while(from<to)
{
t=str[from];
str[from++]=str[to];
str[to--]=t;
}
i++;
}
printf("\nString:%s\n",str);
return 0;
}结果:
本文提供了一个C++和C语言实现的函数,用于将字符串整体翻转,并在保持单词内字符顺序不变的情况下翻转每个单词。通过两步操作,即先整体翻转再对每个单词进行局部翻转,实现复杂字符串的高效处理。
172万+

被折叠的 条评论
为什么被折叠?



