面试经典题目:字符串翻转I am a student

原创 2015年11月18日 15:15:09

  • 只有比别人更早、更勤奋地努力,才能尝到成功的滋味

题目:写一个函数,将字符串翻转,翻转方式如下:“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语言】有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student"

我的思路是,首先将这个字符串整个逆序,再将其中的每一个单词再次逆序,得到最终结果,刚开始没有思路的时候在纸上画画,有助于编程,这是我近期学习C语言的心得。 接下来我们来编程解决这个问题。 #inclu...
  • pointer_y
  • pointer_y
  • 2016年05月21日 00:18
  • 853

有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student".

有一个字符数组的内容为:”student a am i”,请你将数组的内容改为”i am a student”. 要求: 不能使用库函数。只能开辟有限个空间(空间个数和字符串的长度无关)。#i...
  • kai29
  • kai29
  • 2017年11月01日 14:11
  • 188

【C语言】有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student".

有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student". 要求: 不能使用库函数。只能开辟有限个空间(空间个数和字符串的长度无关)。...
  • zgw285763054
  • zgw285763054
  • 2016年01月14日 16:54
  • 1147

将数组&quot;student a am i&quot;改为&quot;i am a student&quot;.

题目:        有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student".要求:不能使用库函数。只能开辟有限个空间(空间个数和字符串的长度无...
  • ttyue_123
  • ttyue_123
  • 2016年08月09日 21:41
  • 154

C 语言字符串 将一行字符串I am a student。逆序输出student。a am I;

方法1 #include #include #define N 4//单词的个数 #define M 20//单词的长度 int main(void) { char str[N][M...
  • ZSS1753936255
  • ZSS1753936255
  • 2016年10月23日 21:27
  • 948

面试题------字符串翻转I am a student

题目描述:编写函数,输入一个英文的句子,翻转句子中单词的顺序。要求单词内字符的顺序不变,单词间空格符数量不变。 例如:"I am a student."反转成"student. a am I"。 ...
  • so_geili
  • so_geili
  • 2017年05月02日 10:24
  • 845

I am a student 单词逆序输出

C++: # include  # include    void fun(char* a,char* b) {     int i,j,k=0; ...
  • wlchn
  • wlchn
  • 2015年08月10日 11:46
  • 332

I am a student. student.a am I

#include ////////////////////////////////////////////////////////////////////////// ///字符串反转,不用库函数...
  • A_sungirl
  • A_sungirl
  • 2016年01月27日 18:41
  • 1220

将字符串student a am i反转为 i am a student

#include #include void reserve_string(char *l, char *r) { while(l < r) { char tmp =...
  • yangrujing
  • yangrujing
  • 2015年05月09日 16:02
  • 1004

字符串“student a am i”转换为"i im a student"

题目: 字符串“student am a i”,现编写代码将字符串转换为“i am a stduent”,要求空间复杂度是O(1) 思路  :用指针的形式,pstart指向字符串头,pen...
  • qq1010234991
  • qq1010234991
  • 2016年06月05日 23:56
  • 423
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:面试经典题目:字符串翻转I am a student
举报原因:
原因补充:

(最多只允许输入30个字)