C++で2つのint配列を取る方法はありますか
int * arr1;
int * arr2;
//pretend that in the lines below, we fill these two arrays with different
//int values
そして、それらを両方の配列の値を含む1つの大きな配列に結合しますか?
int * result = new int[size1 + size2];
std::copy(arr1, arr1 + size1, result);
std::copy(arr2, arr2 + size2, result + size1);
ただ提案、vector
はポインターよりも動的な配列としてより良くなります
配列を使用している場合は、すべての値を格納するのに十分な大きさの新しい配列を割り当ててから、値を配列にコピーする必要があります。これには、配列サイズなどを知る必要があります。
配列の代わりにstd::vector
(他の利点があります)を使用すると、これはより簡単になります。
std::vector<int> results;
results.reserve(arr1.size() + arr2.size());
results.insert(results.end(), arr1.begin(), arr1.end());
results.insert(results.end(), arr2.begin(), arr2.end());
別の方法は、式テンプレートを使用して、2つを連結するふりをすることです(遅延評価)。いくつかのリンク(追加のグーグルを実行できます):
http://www10.informatik.uni-erlangen.de/~pflaum/pflaum/ProSeminar/ http://www.altdevblogaday.com/2012/01/23/abusing-c-with- expression-templates/ http://aszt.inf.elte.hu/~gsd/halado_cpp/ch06s06.html
使いやすさを探しているなら、試してください:
#include <iostream>
#include <string>
int main()
{
int arr1[] = {1, 2, 3};
int arr2[] = {3, 4, 6};
std::basic_string<int> s1(arr1, 3);
std::basic_string<int> s2(arr2, 3);
std::basic_string<int> concat(s1 + s2);
for (std::basic_string<int>::const_iterator i(concat.begin());
i != concat.end();
++i)
{
std::cout << *i << " ";
}
std::cout << std::endl;
return 0;
}
ここに同じ解決策があります-
#include<iostream>
#include<bits/stdc++.h>
using namespace std;
void Concatenate(char *s1,char *s2)
{
char s[200];
int len1=strlen(s1);
int len2=strlen(s2);
int j;
///Define k to store the values on Kth address Kstart from 0 to len1+len2;
int k=0;
for(j=0;j<len1;j++)
{
s[k]=s1[j];
k++;
}
for(j=0;j<len2;j++)
{
s[k]=s2[j];
k++;
}
///To place a null at the last of the concatenated string to prevent Printing Garbage value;
s[k]='\n';
cout<<s;
}
int main()
{
char s1[100];
char s2[100];
cin.getline(s1,100);
cin.getline(s2,100);
Concatenate(s1,s2);
return 0;
}
それが役に立てば幸い。
Int * arr1とint * arr2が与えられた場合、このプログラムは両方の配列の要素をint * arr3に連結します。残念ながら、C++では、コピーする各配列のサイズを知る必要があります。ただし、これは、arr1からコピーする要素の数と、arr2からコピーする要素の数を選択する際の障害にはなりません。
#include <iostream>
using namespace std;
int main(){
int temp[] = {1,2,3,4};
int temp2[] = {33,55,22};
int * arr1, * arr2, *arr3;
int size1(4), size2(3); //size1 and size2 is how many elements you
//want to copy from the first and second array. In our case all.
//arr1 = new int[size1]; // optional
//arr2 = new int[size2];
arr1=temp;
arr2=temp2;
arr3 = new int;
//or if you know the size: arr3 = new int[size1+size2];
for(int i=0; i<size1+size2; i++){
if (i<size1)
arr3[i]=arr1[i];
else
arr3[i] = arr2[i-size1];
}
cout<<endl;
for (int i=0; i<size1+size2; i++) {
cout<<arr3[i]<<", ";
}
}
for (int i = 0; i< arraySize * 2; i++)
{
if (i < aSize)
{
*(array3 + i) = *(array1 + i);
}
else if (i >= arraySize)
{
*(array3 + i) = *(array2 + (i - arraySize));
}
}
これはあなたに役立つかもしれません、それはベクトルを必要としません。プログラミングクラスでも同様の問題が発生しました。これが役立つことを願っています。ポインタ演算を使用する必要がありました。これは、array1とarray2がサイズ「aSize」に動的に初期化されることを前提としています。