あなたはこれを書きました
for (int k = 0; k < 13; k++)
{
for (int j = 0; j< 1; j++)
{
for (int i = 0; i< 4; i++)
{
cabins[13][4][1] = (("b" "i" "i" "b")
これは、配列内のすべての文字を反復処理し、それが機能した場合、または有効な C++ であった場合、配列全体をそのスロットに割り当てようとします。
"(("b" "i" "i" "b")" がどうあるべきかわかりませんが、C++ の基礎をいくつか見逃しているようです。実際に欲しいのは、もっと似たようなものです。
char cabins[13][4]; // only needs to be 2d.
void Ship::setArray()
{
cabins = {
{ 'b', 'i', 'i', 'b' },
{ 'b', 'i', 'i', 'b' },
...
};
}
[編集: ラップトップで作業していて、早めにリターンを押しました。申し訳ありません]
これもうまくいきません。ここでの配列定義が永続的である場合は、それをどこかに保存する必要があります。
これを解決する方法の完全な単一コンパイルユニットの例を次に示します。
#include <iostream>
#include <cstring> // for memcpy
class Ship {
public:
Ship() {}
char m_cabins[4][4];
void setArray();
};
void Ship::setArray() {
static const char defaultCabinLayout[4][4] = {
{ 'b', 'i', 'i', 'b' },
{ 'b', 'i', 'i', 'b' },
{ 'w', 'i', 'i', 'w' },
{ 'w', 'i', 'i', 'w' },
};
static_assert(sizeof(m_cabins) == sizeof(defaultCabinLayout), "defaultCabinLayout does not match m_cabins");
memcpy(m_cabins, defaultCabinLayout, sizeof(m_cabins));
}
int main() {
Ship s;
s.setArray();
std::cout << "cabins[0][0] = " << s.m_cabins[0][0] << std::endl;
}