本文主要是介绍【id:10】【20分】D. 三串合一(指针与字符数组),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目描述
输入三个字符串,通过指针读取各个字符串的子串(子串是指字符串中连续的一小部分),把它们合并成一个新字符串
要求:
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;
}
这篇关于【id:10】【20分】D. 三串合一(指针与字符数组)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!