- 締切済み
構造体で配列を使用しない方法。
- みんなの回答 (3)
- 専門家の回答
みんなの回答
- nk2
- ベストアンサー率23% (6/26)
なぜ配列を使いたくないのかが分からん。 std::vecotr<tmplate T> ではだめか? もし確保するべき配列数が分からないときは、 これを使うのだか。 #include <vector> using namespave std; struct seiseki { vector<char> name; vector<char> rank; };
- BLUEPIXY
- ベストアンサー率50% (3003/5914)
構造体の中の char name[20]; を配列を使わないというような意味だったら char *name; にして、 構造体に値を設定するときにmallocした領域を割り当てます。
- 麻野 なぎ(@AsanoNagi)
- ベストアンサー率45% (763/1670)
まず、 char *str; ままずいですね。欲しいのは、構造体であって、char ではないですから。 この場合、 struct seiseki *str; に対して、 str = malloc(sizeof struct seiseki * 必要数); で領域が確保できます。 str[1] などで、参照もできます。 あと、malloc() の返り値は、void * なので、任意の型のポインタに代入・比較できます。 なので、malloc() の返り値にキャストは不要です。
関連するQ&A
- 構造体について
凄く初歩的な質問で申し訳ありませんが… 入門書の構造体のところで 以下のようなプログラムの例がありました。 #include <stdio.h> struct seiseki { /* 構造体の宣言 */ int no; char name[20]; double average; }; int main(void) { int i; struct seiseki seito1, seito2[20]; /* 構造体変数と構造体配列の宣言 */ >char name[20] というのは、NAMEの領域を20文字 確保すると言うことですよね? >struct seiseki seito1, seito2[20] ここの箇所が分からないのですが seito2[20]の20というのは どうして20なのですか? NAMEだけではないので もっと大きな数字になるような気がするのですが… またseito1の方は どうして数字が何もないんですか? 考え違いをしているところを ご指摘して頂ければ幸いです。
- ベストアンサー
- C・C++・C#
- C言語 list 構造体配列
どうしてもこの問題がわからないので教えてください! 下記の構造体タグ「seiseki」を使って,表に示すデータをもつ構造体配列「list」を作成する. 関数に構造体配列「list」のアドレスを渡す. 関数で構造体ポインタ「*list」を利用して,一番点 数の高い者(1名限定)を調べ,その名前を表示する. struct seiseki{ char name[30]; int score; name score }; 表 佐藤 80 鈴木 75 田中 95 高橋 90
- 締切済み
- その他(学問・教育)
- 構造体型のポインタ変数を含む構造体
struct seiseki_tag { Int32 math ; Int32 english ; Int32 science; } ; typedef struct seiseki_tag SEISEKI ; struct personal_tag { Char name ; Int32 num ; SEISEKI *sptr } : typedef struct personal_tag PERSONAL ; struct info_tag { PERSONAL person_info ; } ; typedef struct info_tag INFO ; たとえば、上記のように3つの構造体があり、PERSONAL構造体のメンバーに SEISEKI構造体の型を持つポインタ変数が含まれているような場合で、下記のように INFO型のポインタ変数からSEISEKI構造体のメンバーを参照する方法を教えてください。 PERSONAL構造体メンバーのnameやnumは INFO *info ; info->person_info.name ; info->person_info.num ; のように参照すると思いますが、sptrが示すSEISEKI構造体のメンバーへの アクセスができません。下記のように参照を試みたのですがコンパイルは 通るのですが、実際に参照できていませんでした。 INFO *info ; SEISEKI *seiseki ; seiseki = info->person_info.sptr ; seiseki->math ; 判りにくい説明で申し訳ありませんが、どなたか教えていただければと思います。 よろしくお願いいたします。
- ベストアンサー
- C・C++・C#
- C言語 構造体配列 list
プログラミングでこの問題がわからないので教えてください! 下記の構造体タグseisekiを使って,表に示すデータをもつ構造体配列listを作成する. 構造体配列listを利用して,一番点数の高い 者を探し,その名前を表示する. struct seiseki{ char name[30]; int score; name score }; 表 佐藤 80 鈴木 75 田中 95 高橋 90
- ベストアンサー
- その他(学問・教育)
- 構造体の配列のアロケート等の方法
基本的な事かもしれないのですが、 構造体の配列をダブルポインタで返すような関数を作成したいのですが、アロケートの仕方と、そもそも配列をダブルポインタで扱う方法が良く分かってないのかもしれません。 どなたかご教授頂けないでしょうか? Webで調べてもなかなか合ったものが見つからないため、こちらに質問させて頂きました。 イメージしているものを↓に途中まで作ってみました。これも合っていない部分があるかもですが。。。 要はアロケートして構造体の配列を作成する部分と、それをfor文で回して参照する方法が、分かっていない主なところです。 #include <stdio.h> #include <memory> typedef struct member{ int id; char* name; } *member_t; int get_result(member_t *pobj) { member_t* obj = NULL; obj = (member_t*)malloc(sizeof(member_t)); memset(obj, 0x00, sizeof(member_t)); char* nm = NULL; char cnmtmp[] = "nakayama"; nm = (char*)malloc(strlen(cnmtmp)+1); memset(nm, 0x00, strlen(cnmtmp)+1); memcpy(nm, cnmtmp, strlen(cnmtmp)); obj->id = 100; obj->name = nm; *pobj = obj; return 0; } int get_resultList(member_t **ppobj) { /* * ココ */ return 0; } void main() { member_t* obj = NULL; get_resultList(&obj); for(int i = 0;;){ /* * ココ */ printf("[%d]\n",i+1); printf("ID : %d\n", ->id); printf("NAME : %s\n", ->name); free( ->name); free( ); } free(obj); } 長々とすみません。
- ベストアンサー
- C・C++・C#
- 構造体の配列について
--------------------------------------------------- #include<stdio.h> #include<string.h> struct person{ char name[80]; int height; int weight; }; int main() { struct person dt[10]; strcpy(dt[1].name,"日本太郎"); //// (1) //// dt[1].weight=70; dt[1].height=180; dt[5]=dt[1]; //// (2) //// printf("%s %d %d \n",dt[1].name,dt[1].weight,dt[1].height); return 0; } ----------------------------------------------------- 以上のプログラムは参考書に記述されていたものですが、(1)の部分で、配列名dtに「"日本太郎"」を設定するならわかるのですが、配列の1つの要素「dt[1]」に「"日本太郎"」を設定しているというように見え、これはエラーが出ると感じたのですが出ません。 char dt[10]; strcpy(dt[1],"日本太郎"); 以上のようにしてしまっているというイメージがあります。 後、(2)の部分もよくイメージがわきません。 以上、どのような仕組みになっているのか教えていただければ嬉しいです。
- ベストアンサー
- C・C++・C#
- 構造体の配列について(2)
前回「構造体の配列について」という質問タイトルで、質問させていただいたのですが、理解が完全ではないため同じようなプログラム内容ではありますが、疑問を書かせていただきます。よろしくお願いします。 ----------------------------------------------------------------------- #include<stdio.h> #include<string.h> struct person{ char name[1]; //// (1) //// int height; int weight; }; int main() { struct person dt[10]; strcpy(dt[0].name,"日本一郎"); strcpy(dt[2].name,"関東次郎"); strcpy(dt[9].name,"関西三郎"); dt[1].weight=99; dt[1].height=168; printf("%s %s %s %d %d \n",dt[0].name,dt[2].name,dt[9].name,dt[1].weight,dt[1].height); return 0; } ----------------------------------------------------------------------- 以上のプログラムの(1)の部分で、文字を1文字しか格納出来ないのに、 strcpy(dt[0].name,"日本一郎"); strcpy(dt[2].name,"関東次郎"); strcpy(dt[9].name,"関西三郎"); としても何故正しく実行できるのかわかりません。 前回いろいろとご回答いただいたのに、しっかりと理解できない者ですが、教えていただければ嬉しいです。
- ベストアンサー
- C・C++・C#