4

トリプル ポインターを使用してみましたが、失敗し続けます。コード:

#include <stdlib.h>
#include <stdio.h>

int set(int *** list) {
  int count, i;
  printf("Enter number:\n");
  scanf("%d", &count);
  (*list) = (int **) malloc ( sizeof (int) * count);

  for ( i = 0; i<count;i++ ) {
    (**list)[count] = 123;
  }
  return count;
}

int main ( int argc, char ** argv )
{
  int ** list;
  int count;

  count = set(&list);

  return 0;
}

アドバイスをありがとう

4

3 に答える 3

7

リストと呼ぶものは、実際には配列です。次の方法で行うことができます。

#include <stdlib.h>
#include <stdio.h>

ssize_t set(int ** ppList) 
{
  ssize_t count = -1;

  printf("Enter number:\n");
  scanf("%zd", &count);

  if (0 <= count)
  {
    (*ppList) = malloc(count * sizeof **ppList);

    if (*ppList)
    {
      size_t i = 0;
      for (; i < count; ++i)
      {
        (*ppList)[i] = 42;
      }
    }
    else
    {
      count = -1;
    }
  }

  return count;
}

int main (void)
{
  int * pList = NULL;
  size_t count = 0;

  {
    ssize_t result = set(&pList);

    if (0 > result)
    {
      perror("set() failed");
    }
    else
    {
      count = result;
    }
  }

  if (count)
  {
    /* use pList */
  }

  ...

  free(pList);

  return 0;
}
于 2012-11-03T11:43:28.833 に答える
4

私があなたの質問を理解している限り、別の関数で割り当てられた配列を返したいと思っています:これはこれの単純なバージョンです

#include<stdio.h>
#include<stdlib.h>
int* set(int *list) {
  int count, i;
  printf("Enter number:\n");
  scanf("%d", &count);
  list = (int *) malloc ( sizeof (int) * count);

  for ( i = 0; i<count;i++ ) {
    list[i] = 123;
  }

  return list;
}

int main ( int argc, char ** argv )
{
  int *list;
  list = set(list);
  //Use whatever you want to do with that array 
  free(list); // don't forget to free
  return 0;
}
于 2012-11-03T11:44:54.697 に答える
1

整数配列の配列があります。set 関数を詳しく見てみましょう。

for (i = 0; i < count;i++ ) {
    (**list)[count] = 123;
}

ご覧のとおり、すべての配列オブジェクトを整数値のように扱っています。それはネストされたループでなければなりません:

for (i to n)
    // allocate each array
    for (k to m)
        // assign value for each value of array
于 2012-11-03T11:32:06.870 に答える