题目描述
输入三个字符串,通过指针读取各个字符串的子串(子串是指字符串中连续的一小部分),把它们合并成一个新字符串
要求:
1. 三个字符串的创建和输入可以使用数组,也可以不用
2. 输入后,根据三个字符串的子串的长度,计算出新字符串的长度
3. 使用动态数组的方法创建新的字符串,并且使用指针读取三个字符串的不同部分,并且复制到新字符串中,要求整个过程都不能使用数组下标
4. 使用指针输出新的字符串
输入
第一行输入t表示有t个测试实例
连续三行输入三个字符串,每个字符串都包含10个字符
连续三行,每行输入数字a和b,表示每个子串的开始和结束位置。注意字符串的位置是按照一般意义从1开始计算,和编程中的数组位置不同。例如字符串abcdefg,开始位置是3,结束位置是5,那么子串就是cde
依次输入t个实例
输出
每行输出合并后的新字符串
代码实现:
#include<iostream>
using namespace std;
int main()
{
int t;
cin >> t;
while (t--)
{
char a[15];
char b[15];
char c[15];
cin >> a;
cin >> b;
cin >> c;
int a1, b1;
int a2, b2;
int a3, b3;
cin >> a1 >> b1;
cin >> a2 >> b2;
cin >> a3 >> b3;
int len1 = b1 - a1 + 1;
int len2 = b2 - a2 + 1;
int len3 = b3 - a3 + 1;
int len = len1 + len2 + len3;
char* newone = new char[len];
char* p1 = a + a1 - 1;
char* p2 = b + a2 - 1;
char* p3 = c + a3 - 1;
for (int i = 0; i < len; i++)
{
if (i < len1)
{
newone[i] = p1[i];
}
else if (i >= len1 && i < len1 + len2)
{
newone[i] = p2[i - len1];
}
else
{
newone[i] = p3[i - len1 - len2];
}
}
for (int i = 0; i < len; i++)
{
cout << newone[i];
}
cout << endl;
}
return 0;
}