forループから読み取った値を配列に格納したい
char A[];
int x;
int y=5;
for( int i=0; int i =1000; i++) {
x = x+y;
// then store/append x as elements of the char array, A.... what is the syntax?
}
あなたのコードを見ると、静的配列を構築しようとしていると思われるので、それを示します (したがって、当面は malloc のような概念に集中する必要はありません)。ただし、あなたのコードにはいくつかの問題があります。
まず、配列宣言から:
char A[];
forループが整数の配列を埋めているように見えるので、この配列は整数として宣言する必要があります。さらに、配列のサイズを設定していません。コードは1000になるまでインクリメントするため、宣言する必要があります1000 要素の整数配列:
int A[1000];
2 番目の for ループ:
for(int i = 0, int i = 1000; i++)
for ループで宣言することもできますが、残りの変数で宣言する方がよいi
でしょう。個人的にはお勧めしません。i
また、このループで 2 回宣言します。最後に、ループを続行する条件 ( ) は、 に設定してからと等しくならないi = 1000
ため、すぐにループを中止します。for ループは、中間ステートメントが true の間だけループすることを覚えておいてください。したがって、それを念頭に置いて、次のものが必要です。i
1000
0
int A[1000], i, x, y = 5;
for(i = 0; i < 1000; i++)
=
これで、 のステートメントと値を使用して、i
各配列要素を に設定できA
ます。
int A[1000], i, x, y = 5;
for(i = 0; i < 1000; i++)
{
x += y;
A[i] = x;
}
それはとても簡単です!
コードに複数の問題があります
char A[1000]; // Need to specify a compile time constant for the array size
int x=0;
int y=5;
for( int i=0; i < 1000; i++) { // Condition was wrong
x = x+y;
// then store/append x as elements of the char array, A.... what is the syntax?
A[i] = x; // Add the value
}
また、char
データ型は特定のサイズを超える値を保持できず、オーバーフローが発生して値が折り返されます。代わりにA
asを宣言することもできます。int A[1000]
malloc
i
。あなたのように代入文がある場合も、永遠にループします。代わりに1000までループしたいと思います[]
演算子を使用します。x
何にも初期化されていないため、ガベージ値が含まれています。変数を宣言するときに、変数に値を割り当てる必要があります。C はこれを自動的に行いません。C で要素を追加する場合、いくつかの方法があります。
静的配列
静的配列は、編集できない多くの要素で宣言されています。したがって、要素の数が正確にわかっていれば完璧です。@Dervallはそれをうまく説明しました。
動的配列
malloc関数で動的配列を宣言しています。しかもサイズ変更可能。とはいえ、維持するのは難しくて大変です。しかし :
int *A = NULL;
int *tmp; // to free ex allocated arrays
int i;
int j;
int x = 0;
int y = 5;
for (i = 0 ; i < 1000 ; i++) {
// saving temporarly the ex array
tmp = A;
// we allocate a new array
if ((A = malloc(sizeof(int) * (i + 1))) == NULL) {
return EXIT_FAILURE;
}
// we fill the new array allocated with ex values which are in tmp
for (j = 0; j < i; j++) {
A[j] = tmp[j];
}
// if it's not the first time, we free the ex array
if (tmp != NULL)
free(tmp);
x = x + y;
A[i] = x;
}
もちろん、それを関数に分割することをお勧めします:)
機能も使えるrealloc
!そのために作られたものですが、こういう展開は面白いと思います
スニペットには多くの問題があります。これがコンパイル可能な例です
char *A = malloc(sizeof(*A) * NUM_ELEMENTS); // you shouldn't declare on the stack
int x = 0; // initialize
int y=5;
for( int i = 0; i < NUM_ELEMENTS; i++) { // proper for loop syntax
x = x+y;
A[i]=x; // assign element of array
}
そしてより良いバージョン:
char *A = malloc(sizeof(*A) * NUM_ELEMENTS);
for (int i = 0; i < NUM_ELEMENTS; ++i)
A[i] = 5 * i;