[PTA]实验8-1-6 函数实现字符串逆序

Posted Spring-_-Bear

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[PTA]实验8-1-6 函数实现字符串逆序相关的知识,希望对你有一定的参考价值。

本题要求实现一个字符串逆序的简单函数。

函数接口定义:

void f( char *p );

函数f对p指向的字符串进行逆序操作。要求函数f中不能定义任何数组,不能调用任何字符串处理函数。

裁判测试程序样例:

#include <stdio.h>
#define MAXS 20

void f( char *p );
void ReadString( char *s ); /* 由裁判实现,略去不表 */

int main()
{
    char s[MAXS];

    ReadString(s);
    f(s);
    printf("%s\\n", s);

    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

Hello World!

输出样例:

!dlroW olleH
  • 提交结果:

在这里插入图片描述

  • 源码:
#include <stdio.h>
#define MAXS 20

void f(char* p);
void ReadString(char* s); /* 由裁判实现,略去不表 */

int main()
{
    char s[MAXS];

    ReadString(s);
    f(s);
    printf("%s\\n", s);

    return 0;
}

/* 你的代码将被嵌在这里 */
void f(char* p)
{
	int len = 0;

	// 获得字符串长度
	for (int i = 0; p[i] != '\\0'; i++)
	{
		len++;
	}

	// 尾游标
	int tailIndex = len - 1;

	// 首尾两个字符分别交换
	for (int i = 0; i < len / 2; i++)
	{
		char temp;
		temp = p[i];
		p[i] = p[tailIndex];
		p[tailIndex] = temp;

		tailIndex--;
	}
}

// 自我实现,假设以#结束字符串输入
void ReadString(char *s) /* 由裁判实现,略去不表 */
{
	for (int i = 0; i < MAXS; i++)
	{
		s[i] = getchar();

		if (s[i] == '#')
		{
			s[i] = '\\0';
			break;
		}
	}
}

以上是关于[PTA]实验8-1-6 函数实现字符串逆序的主要内容,如果未能解决你的问题,请参考以下文章

[PTA]实验11-2-3 逆序数据建立链表

[PTA]实验7-3-1 字符串逆序

[PTA]习题6-6 使用函数输出一个整数的逆序数

[PTA]实验8-2-4 使用函数实现字符串部分复制

[PTA]实验7-1-3 将数组中的数逆序存放

[PTA]实验6-2 分类统计字符个数