东南大学c++期末考试代码题

该文章描述了一个C++编程题,要求建立一个str类来处理字符串的循环左移操作。类应包含指向字符串的指针、移动次数和字符串长度等数据成员,以及构造函数、移动方法和显示方法。给定示例中,对字符串ABCD左移3个字符后得到DCBA。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一道上机编程题题目如下:

  1. 建立一个 str 类,完成对字符串循环左移的功能。即从第二个字符开始,以后的每个
    字符都依次前移一个字符,而原来的第一个字符放在串中的最后一个字符。当要平移 m 个
    字符时,则要进行 m 次的循环左移。例如:“ABCD”循环左移 2 个字符后为“CDAB”。要
    求如下:
    (1)私有数据成员
    char * w;指向待左移字符串。
    int m, len; 分别用于存储循环左移的次数及字符串的长度。
    (2)公有成员函数
    构造函数 str(char *p, int n, int k):初始化各数据成员。
    void move():循环左移。
    void show():输出字符串数据成员
    (3)编写一个程序测试该类,使用以下测试数据:a[]=”ABCD”,左移 3 个字符。要求输出字
    符串。
#include<iostream>
#include<string>
using namespace std;
class str
{
	char* w;
	int m, len;
public:
	str(char* p, int n, int k)
	{
		w = p;
		m = n;
		len = k;
	}
	void move()
	{
		for (int j = 0; j < m; j++)
		{
			char temp = *w;
			for (int i = 0; i < len - 1; i++)
			{
				*(w + i) = *(w + i + 1);

			}
			*(w + len - 1) = temp;
		}
	}
	void show()
	{
		cout << w << endl;

	}
};
int main()
{
	char a[] = "abcd";
	str x(a, 3, 4);
	x.move();
	x.show();
}

结果:
请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值