Given a string, you need to reverse the order of characters in each word within a sentence while still preserving whitespace and initial word order.
Input: "Let's take LeetCode contest"
Output: "s'teL ekat edoCteeL tsetnoc"
Note: In the string, each word is separated by single space and there will not be any extra space in the string.
注意: 在字符串中,每个单词都以单个空格分隔,字符串中不会有任何额外的空格。
给定一个字符串,需要颠倒一个句子中每个单词中的字符顺序,同时仍保留空格和初始单词顺序。
挺简单的题,只需要将句子中每个单词中的字母颠倒顺序,其他东西保持不变就行。
思路:
#include
#include
using namespace std;
class Solution {
public:
//思路:
//1.英文句子分割成一个个单词
//2.将每个单词反转 (以单词中间字母为中心,前后对称位置的字母交换位置)
string reverseWords(string s) {
string res = s;//复制
int left = 0, right = 0;//记录左右下标
for(int i=0; i1; i++)//res.length()+1为了遍历到最后的'\0'
{
if(res[i] == ' '|| res[i] == '\0')//空格或结束符的左邻字符下标 即为 目前单词位置的右下标
{
left = right;
right = i - 1;//空格的上一位表示单词的最后一位
int L = left,R = right;//交换单词
for(; Lchar temp = res[R];
res[R] = res[L];
res[L] = temp;
}
right = i+1;//空格或结束符的右邻字符下标 即为 下个单词位置的左下标
}
}
return res;
}
};
int main()
{
Solution A;
string a;
getline(cin,a);
//cin >> a;//只能输入没有空格的字符串,当输入中含有空格,则只能输出空格之前的字符
cout << A.reverseWords(a) << endl;
return 0;
}
注意:
c/c++中获取字符串长度,size()、sizeof() 、strlen()、str.length();
1). sizeof():返回所占总空间的字节数.
sizeof()是运算符,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。
2). strlen():返回字符数组或字符串所占的字节数
strlen()是函数,要在运行时才能计算。参数必须是字符型指针(char*)。当数组名作为参数传入时,实际上数组就退化成指针了。
它的功能是:返回字符串的长度。该字符串可能是自己定义的,也可能是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符’\0’。返回的长度大小不包括’\0’。
strlen(char*)函数求的是字符串的实际长度,它求得方法是从开始到遇到第一个’\0’,如果你只定义没有给它赋初值,这个结果是不定的,它会从aa首地址一直找下去,直到遇到’\0’停止。
c/c++ strlen(str)和str.length()和str.size()都可以求字符串长度。
其中str.length()和str.size()是用于求string类对象的成员函数
strlen(str)是用于求字符数组的长度,其参数是char*。
举例:
1)char* ss = “0123456789”;
sizeof(ss)为4,ss是指向字符串常量的字符指针,sizeof 获得的是指针所占的空间,则为4
sizeof(*ss)为1,*ss是第一个char字符,则为1
2)char ss[] = “0123456789”;
sizeof(ss)为11,ss是数组,计算到’\0’位置,因此是(10+1)
sizeof(*ss)为1,*ss是第一个字符
3)char ss[100] = “0123456789”;
sizeof(ss)为100,ss表示在内存中预分配的大小,100*1
strlen(ss)为10,它的内部实现用一个循环计算字符串的长度,直到’\0’为止。
4)int ss[100] = “0123456789”;
sizeof(ss)为400,ss表示在内存中预分配的大小,100*4
strlen(ss)错误,strlen参数只能是char*,且必须是以’\0’结尾
5)char[] a={‘a’,’b’,’c’};
sizeof(a)的值应该为3。
char[] b={“abc”};
sizeof(b)的值应该是4。
若string str={‘a’,’b’,’c’,’\0’,’X’};
那么sizeof(str)为5,strlen(str)为3。
sizeof()、strlen()两者区别:
1)sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。
该类型保证能容纳实现所建立的最大对象的字节大小。
2)sizeof是运算符,strlen是函数。
3)sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以”\0”结尾的。
sizeof还可以用函数做参数,比如:
short f();
printf("%d\n", sizeof(f()));
输出的结果是sizeof(short),即2。
4)数组做sizeof的参数不退化,传递给strlen就退化为指针了。
5)大部分编译程序 在编译的时候就把sizeof计算过了 是类型或是变量的长度。这就是sizeof(x)可以用来定义数组维数的原因
char str[20]="0123456789";
int a=strlen(str); //a=10;
int b=sizeof(str); //而b=20;
6)strlen的结果要在运行的时候才能计算出来,用来计算字符串的长度,不是类型占内存的大小。
7)sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数。
8)当使用了一个结构类型或变量时, sizeof 返回实际的大小, 当使用一静态地空间数组, sizeof 返回全部数组的尺寸。 sizeof 操作符不能返回被动态分配的数组或外部的数组的尺寸
2.string中length()和size()
c++中的size()和length()没有区别
string str="0123456789";
cout <<"str.length()="<<str.length()<//结果为10
cout <<"str.size()="<<str.size()<//结果为10
为了兼容,这两个函数一样。 length()是因为沿用C语言的习惯而保留下来的,string类最初只有length(),引入STL之后,为了兼容又加入了size(),它是作为STL容器的属性存在的,便于符合STL的接口规则,以便用于STL的算法。 string类的size()/length()方法返回的是字节数,不管是否有汉字。