笔试题目“翻转字符串”的实现

本文介绍了一道常见的笔试题——如何在不使用库函数的情况下,用C++实现字符串翻转,例如将'I am a student'翻转为'student a am I'。作者分享了自己的实现方法。

最近找实习,要面试各种公司,据说这题在笔试或者面试当中,出现的频率非常高

//写一个函数,将字符串翻转,翻转方式如下:“I am a student”反转成“student a am I”,不借助任何库函数。


我自己写了个实现:

/*
*将字符串翻转
*翻转方式如下:“I am a student”反转成“student a am I”
*
*方法:
*先反转整个字符串,然后再反转字串。
*譬如先将“I am a student”反转为“tneduts a ma I”,
*然后再对每个字串(空格分割)反转一次。
*空间复杂度O(1),时间复杂度O(n)
*/
int main(int argc, char* argv[])
{
	char src[] = "you are a student!";

	char* begin = src;
	char* end = src;
	while(*end != '\0')
		++end;
	--end;
	char tmp;
	while(begin < end)
	{
		tmp = *begin;
		*begin = *end;
		*end = tmp;
		++begin;
		--end;
	}//reverse all

	char* index = src;
	while(true)
	{
		begin = index;
		while(*index != '\0' && *index != ' ')
			++index;

		end =index-1;
		if(*index != '\0')
			++index;

		while(begin < end)
		{
			tmp = *begin;
			*begin = *end;
			*end = tmp;
			++begin;
			--end;
		}

		if(*index == '\0')
			break;
	}

	printf(src);
	printf("\n");

	return 0;
}

另外下面是《程序员面试宝典》的代码,一起贴在下面:

#include <iostram>
#include <stdio.h>

int main(void)
{
    int num=-12345,j=0,i=0,flag=0,begin,end;
    char str[]="I am a student",temp;
    j=strlen(str)-1;
    
    printf(" string=%s\n",str);
    //第一步是进行全盘反转,将单词变成“tneduts a ma I”
    while(j>i)
    {
        temp=str[i];
        str[i]=str[j];
        str[j]=temp;
        j--;
        i++;
    }
    printf(" string=%s\n",str);
    int i=0;
    //第二步进行部分反转,如果不是空格则开始反转单词
    while(str[i])
    {
        if(str[i]!=' ')
        {
            begin=i;
            while(str[i]&&str[i]!=' ')
            {
                i++;
            }
            i=i-1;
            end=i;
        }
        while(end>begin)
        {
            temp=str[begin];
            str[begin]=str[end];
            str[end]=temp;
            end--;
            begin++;
        }
        i++;
    }
    printf(" string=%s\n",str);
    return 0;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值