質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.37%

C言語 coredump 解決法

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 700

score 18

<修正後>

#include <stdio.h>    
#include <string.h>
#include <stdlib.h>
#define MAX 10
/*--- int 型スタックを実現する構造体 ---*/

typedef struct{
    double vision; /* 視力 */
    int height; /* 身長 */
} Body ;
/*--- 身体検査データ型 ---*/
typedef struct{
    Body body; /* 身体データ型 ---*/
    char *name; /* 氏名 */
} PhysCheck ;
typedef struct {
    int max; /* スタックの容量 */
    int ptr; /* スタックポインタ */
    PhysCheck stk[MAX]; /* スタック本体*/
} PhysCheckStack;

int Search(PhysCheckStack *s , PhysCheck *x){
    int count = 0;
    for(int i = 0 ; i < s->ptr ; i ++){
        if(strcmp(x->name,s->stk[i].name) == 0){//string compare 文字一致したら0返す
            printf("%s %f %d\n",s->stk[i].name,s->stk[i].body.vision,s->stk[i].body.height);
            count ++;
        }
    }
    return count;
}

/*--- スタックの初期化 ---*/
int Initialize(PhysCheckStack *s, int max){
    s->ptr = 0;
    if ((s->stk[s->ptr].name = calloc(max, sizeof(char*))) == NULL) {
        s->max = 0; /* char* の配列の確保に失敗 */
        return -1;
    }
    s->max = max;
    return 0;
}
/*--- スタックにデータをプッシュ ---*/
int Push(PhysCheckStack *s, PhysCheck *x){
    if (s->ptr >= s->max) return -1; /* スタック満杯 */
    strcpy(s->stk[s->ptr].name,x->name);
    if ((s->stk[s->ptr].name = calloc(strlen(x->name)+1, sizeof(char*))) == NULL)
        /* データをコピーするための動的な文字列保存用配列を確保することに失敗 */
        return -1;
    s->stk[s->ptr].body.vision = x->body.vision;
    s->stk[s->ptr].body.height = x->body.height;
    s->ptr++;
    return 0;
}
/*--- スタックからデータをポップ ---*/
int Pop(PhysCheckStack *s, PhysCheck *x){
    if (s->ptr <= 0) return -1; /* スタックは空 */
    s->ptr--;
    strcpy(x->name,s->stk[s->ptr].name);
    x->body.vision = s->stk[s->ptr].body.vision;
    x->body.height = s->stk[s->ptr].body.height;
    free(s->stk[s->ptr].name); 
    return (0);
}
/*--- スタックからデータをピーク ---*/
int Peek(PhysCheckStack *s, PhysCheck *x){
    if (s->ptr <= 0) return -1;
    strcpy(x->name,s->stk[s->ptr-1].name);
    x->body.vision = s->stk[s->ptr-1].body.vision;
    x->body.height = s->stk[s->ptr-1].body.height;
    return 0;
}
/*--- スタックの容量 ---*/
int Capacity(const PhysCheckStack *s){
    return s->max;
}
/*--- スタックに積まれているデータ数 ---*/
int Size(const PhysCheckStack *s){
    return s->ptr;
}
/*--- スタックの全データの表示 ---*/
void Print(const PhysCheckStack *s){
    int i;

    for(i = 0; i < s->ptr; i++)
        printf("%s %f %d", s->stk[i].name,s->stk[i].body.vision,s->stk[i].body.height);
    putchar('\n');
}
int main(void){
    PhysCheckStack s;
    PhysCheck x;
    Initialize(&s, MAX);
    while (1) {
        int menu;
        printf("現在のデータ数:%d/%d\n",Size(&s), Capacity(&s));
        printf("(1) プッシュ (2) ポップ (3) ピーク (4) 表示 (5) 探索 (0) 終了:");
        scanf("%d", &menu);
        if (menu == 0) break;
        switch (menu) {
        case 1: /* プッシュ */
            printf("データ:");
            scanf("%d", &x.body.height);
            scanf("%s",x.name);
            scanf("%lf",&x.body.vision);
            if (Push(&s, &x) == -1)
                puts("\a エラー:プッシュに失敗しました。");
            break;
        case 2: /* ポップ */
            if (Pop(&s, &x) == -1)
                puts("\a エラー:ポップに失敗しました。");
            else
                printf("ポップしたデータは%s %.1f %d です。\n", x.name,x.body.vision,x.body.height);
            break;
        case 3: /* ピーク */
            if (Peek(&s, &x) == -1)
                puts("\a エラー:ピークに失敗しました。");
            else
                printf("ピークしたデータは%s %.1f %d です。\n", x.name,x.body.vision,x.body.height);
            break;
        case 4: /* 表示 */
            Print(&s);https://www.onlinegdb.com/fork/HyZW3BAi8#tab-stdin
            break;
        case 5://探索
            scanf("%s",x.name);
            int search = Search(&s,&x);
            if(search == 0){
                puts("パターンは存在しません");
            } else{
                printf("%dパターンあります\n",search);
            }
        }
    }
    return 0;
}


<したいこと>
最初のメニューで1を選択し、push関数に111、aaa、111と入力して、スタックにプッシュします。
メニューで5を選択して、aと入力するとs->ptrが指してる0を返すプログラムを作りたいです。
<現在>
二回プッシュするとSegmentation fault (core dumped) と表示されます。

<質問>
プッシュ、サーチが出来るように実装したいです
char *nameは変えずにコード作成したいです。

<追記>

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
/*--- int 型スタックを実現する構造体 ---*/

typedef struct{
    double vision; /* 視力 */
    int height; /* 身長 */
} Body ;
/*--- 身体検査データ型 ---*/
typedef struct{
    Body body; /* 身体データ型 ---*/
    char *name; /* 氏名 */
} PhysCheck ;
typedef struct {
    int max; /* スタックの容量 */
    int ptr; /* スタックポインタ */
    PhysCheck **stk; /* スタック本体*/
} PhysCheckStack;

int Search(PhysCheckStack *s , PhysCheck *x){
    for(int i = s->ptr-1 ; i >= 0 ; i --){
        if(strncmp(s->stk[i]->name, x->name ,strlen(x->name)) == 0){//strncmp先頭n文字を比較
            return i;
        }
    }
    return -1;
}

/*--- スタックの初期化 ---*/
int Initialize(PhysCheckStack *s, int max){
    s->ptr = 0;
    if ((s->stk = calloc(max, sizeof(PhysCheck *))) == NULL) {
        s->max = 0; /* char* の配列の確保に失敗 */
        return -1;
    }
    s->max = max;
    return 0;
}
/*--- スタックにデータをプッシュ ---*/
int Push(PhysCheckStack *s, PhysCheck *x){
    if (s->ptr >= s->max) return -1; /* スタック満杯 */
    if ((s->stk[s->ptr] = calloc(strlen(x->name)+1, sizeof(PhysCheck *))) == NULL)
        /* データをコピーするための動的な文字列保存用配列を確保することに失敗 */
        return -1;
    s->stk[s->ptr]->name = calloc(strlen(x->name)+1, sizeof(char));
    strcpy(s->stk[s->ptr]->name,x->name);
    s->stk[s->ptr]->body.vision = x->body.vision;
    s->stk[s->ptr]->body.height = x->body.height;
    s->ptr++;
    return 0;
}
/*--- スタックからデータをポップ ---*/
int Pop(PhysCheckStack *s, PhysCheck *x){
    if (s->ptr <= 0) return -1; /* スタックは空 */
    s->ptr--;
    strcpy(x->name,s->stk[s->ptr]->name);
    x->body.vision = s->stk[s->ptr]->body.vision;
    x->body.height = s->stk[s->ptr]->body.height;
    free(s->stk[s->ptr]->name);
    return (0);
}
/*--- スタックからデータをピーク ---*/
int Peek(PhysCheckStack *s, PhysCheck *x){
    if (s->ptr <= 0) return -1;
    strcpy(x->name,s->stk[s->ptr-1]->name);
    x->body.vision = s->stk[s->ptr-1]->body.vision;
    x->body.height = s->stk[s->ptr-1]->body.height;
    return 0;
}
/*--- スタックの容量 ---*/
int Capacity(const PhysCheckStack *s){
    return s->max;
}
/*--- スタックに積まれているデータ数 ---*/
int Size(const PhysCheckStack *s){
    return s->ptr;
}
/*--- スタックの全データの表示 ---*/
void Print(const PhysCheckStack *s){
    int i;

    for(i = 0; i < s->ptr; i++)
        printf("%s %f %d\n", s->stk[i]->name,s->stk[i]->body.vision,s->stk[i]->body.height);
    putchar('\n');
}
void Terminate(PhysCheckStack *s){
    if(s->stk != NULL)
        free(s->stk);
    s->max = s->ptr = 0;
}
int main(void){
    PhysCheckStack s;
    PhysCheck x;
    int max;
    char y[100];
    printf("スタックの大きさを入力してください");
    scanf("%d", &max);
    if (Initialize(&s, max)==-1){
        puts("スタックの生成に失敗しました.\n");
    }
    while (1) {
        int menu;
        printf("現在のデータ数:%d/%d\n",Size(&s), Capacity(&s));
        printf("(1) プッシュ (2) ポップ (3) ピーク (4) 表示 (5) 探索 (0) 終了:");
        scanf("%d", &menu);
        if (menu == 0) break;
        switch (menu) {
        case 1: /* プッシュ */
            printf("データ:");
            scanf("%d", &x.body.height);
            scanf("%s",y);
            x.name = (char *)malloc(sizeof(char)*(strlen(y) + 1));
            strcpy(x.name,y);
            scanf("%lf",&x.body.vision);
            if (Push(&s, &x) == -1)
                puts("\a エラー:プッシュに失敗しました。");
            break;
        case 2: /* ポップ */
            if (Pop(&s, &x) == -1)
                puts("\a エラー:ポップに失敗しました。");
            else
                printf("ポップしたデータは%s %.1f %d です。\n", x.name,x.body.vision,x.body.height);
            break;
        case 3: /* ピーク */
            if (Peek(&s, &x) == -1)
                puts("\a エラー:ピークに失敗しました。");
            else
                printf("ピークしたデータは%s %.1f %d です。\n", x.name,x.body.vision,x.body.height);
            break;
        case 4: /* 表示 */
            Print(&s);
            break;
        case 5://探索
            scanf("%s",x.name);
            int search = Search(&s,&x);
            if(search == -1){
                puts("パターンは存在しません");
            } else{
                printf("名前に含まれるパターンは%d個です\n",search);
            }
        }
    }
    return 0;
}


自分なりにやってみました。おそらくもっと効率の良いプログラムがあると思っていますが、今の自分でできることはしました。
ポインタについて勉強しなおします。。。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • episteme

    2020/06/05 22:30

    教本ひととおり読んではいかがか?

    キャンセル

回答 4

+1

typedef struct{
    Body body; /* 身体データ型 ---*/
    char *name[20]; /* 氏名 */
} PhysCheck ;

氏名(文字列)を20個持ってるんですか?
それはあなたの意図したものですか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/06/05 23:23

    すいませんミスです。
    いま更新します。

    キャンセル

  • 2020/06/06 00:08

    > scanf("%s",x.name);
    確保されていない領域に読みこもうとしたら、
    そりゃSegmentation fault起こすでしょうよ。

    誤りはここだけじゃなく、いたるところにあります。
    いちいち指摘してられません。

    「やりなおし」

    キャンセル

check解決した方法

0

ぽいんたのがくしゅうぶそく
再学習

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

...こんなもんかしら

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>    
#include <string.h>
#include <stdlib.h>
#include <stdbool.h>

typedef struct {
    double vision; /* 視力 */
    int height; /* 身長 */
} Body;

/*--- 身体検査データ型 ---*/
typedef struct {
    Body body; /* 身体データ型 ---*/
    char name[20]; /* 氏名 */
} PhysCheck;

void PhysCheckCopy(PhysCheck* dst, const PhysCheck* src) {
    dst->body.height = src->body.height;
    dst->body.vision = src->body.vision;
    strcpy(dst->name, src->name);
}

PhysCheck* PhysCheckDup(const PhysCheck* x) {
  PhysCheck* p = (PhysCheck*)malloc(sizeof(PhysCheck));
  if ( p != NULL ) {
    PhysCheckCopy(p,x);
  }
  return p;
} 

bool PhysCheckEqual(const PhysCheck* a, const PhysCheck* b) {
  return strcmp(a->name, b->name) == 0;
}

void PhysCheckPrint(const PhysCheck* x) {
    printf("%s %f %d\n", x->name, x->body.vision, x->body.height);
}

typedef struct {
    int max; /* スタックの容量 */
    int ptr; /* スタックポインタ */
    PhysCheck** stk; /* スタック本体*/
} PhysCheckStack;

int Search(const PhysCheckStack* s, const PhysCheck* x) {
    int count = 0;
    for (int i = 0; i < s->ptr; i++) {
        if ( PhysCheckEqual(s->stk[i], x) ) {
            PhysCheckPrint(s->stk[i]);
            count++;
        }
    }
    return count;
}

/*--- スタックの初期化 ---*/
bool Initialize(PhysCheckStack* s, int max) {
    s->stk = (PhysCheck**)calloc(max, sizeof(PhysCheck*));
    if ( s->stk == NULL ) {
        return false;
    }
    s->ptr = 0;
    s->max = max;
    return true;
}

/*--- スタックにデータをプッシュ ---*/
bool Push(PhysCheckStack* s, const PhysCheck* x) {
    if (s->ptr >= s->max) return false; /* スタック満杯 */
    PhysCheck* y = PhysCheckDup(x);
    if ( y == NULL ) return false;
    s->stk[s->ptr] = y;
    s->ptr++;
    return true;
}

/*--- スタックからデータをポップ ---*/
bool Pop(PhysCheckStack* s, PhysCheck* x) {
    if (s->ptr <= 0) return false; /* スタックは空 */
    s->ptr--;
    PhysCheckCopy(x, s->stk[s->ptr]);
    free(s->stk[s->ptr]);
    return true;
}

/*--- スタックからデータをピーク ---*/
bool Peek(PhysCheckStack* s, PhysCheck* x) {
    if (s->ptr <= 0) return false;
    PhysCheckCopy(x, s->stk[s->ptr - 1]);
    return true;
}

/*--- スタックの容量 ---*/
int Capacity(const PhysCheckStack* s) {
    return s->max;
}

/*--- スタックに積まれているデータ数 ---*/
int Size(const PhysCheckStack* s) {
    return s->ptr;
}

/*--- スタックの全データの表示 ---*/
void Print(const PhysCheckStack* s) {
    int i;

    for (i = 0; i < s->ptr; i++)
        PhysCheckPrint(s->stk[i]);
    putchar('\n');
}

/*--- スタックの廃棄 ---*/
void Terminate(PhysCheckStack* s) {
    PhysCheck x;
    while ( Size(s) > 0 ) {
      Pop(s,&x);
    }
    free(s->stk);
}

int main(void) {
    PhysCheckStack s;
    PhysCheck x;
    Initialize(&s, 10);
    while (1) {
        int menu;
        printf("現在のデータ数:%d/%d\n", Size(&s), Capacity(&s));
        printf("(1) プッシュ (2) ポップ (3) ピーク (4) 表示 (5) 探索 (0) 終了:");
        scanf("%d", &menu);
        if (menu == 0) break;
        switch (menu) {
        case 1: /* プッシュ */
            printf("データ(name vision height):");
            scanf("%s", x.name);
            scanf("%lf", &x.body.vision);
            scanf("%d", &x.body.height);
            if ( !Push(&s, &x) )
                puts("\a エラー:プッシュに失敗しました。");
            break;
        case 2: /* ポップ */
            if ( !Pop(&s, &x) ) {
                puts("\a エラー:ポップに失敗しました。");
            } else {
                printf("ポップしたデータは");
                PhysCheckPrint(&x);
            }
            break;
        case 3: /* ピーク */
            if ( !Peek(&s, &x) ) {
                puts("\a エラー:ピークに失敗しました。");
            } else {
                printf("ピークしたデータは");
                PhysCheckPrint(&x);
            }
            break;
        case 4: /* 表示 */
            Print(&s);
            break;
        case 5://探索
            scanf("%s", x.name);
            int search = Search(&s, &x);
            if ( search == 0 ) {
                puts("パターンは存在しません");
            } else {
                printf("%dパターンあります\n", search);
            }
        }
    }
    Terminate(&s);
    return 0;
}

[追記] char* name 版

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>    
#include <string.h>
#include <stdlib.h>
#include <stdbool.h>

typedef struct {
    double vision; /* 視力 */
    int height; /* 身長 */
} Body;

/*--- 身体検査データ型 ---*/
typedef struct {
    Body  body; /* 身体データ型 ---*/
    char* name; /* 氏名 */
} PhysCheck;

PhysCheck* PhysCheckCreate(const char* name, double vision, int height) {
    PhysCheck* p = (PhysCheck*)malloc(sizeof(PhysCheck));
    if (p != NULL) {
        p->name = (char*)malloc(strlen(name) + 1);
        if (p->name == NULL) {
            free(p);
            p = NULL;
        }
        else {
            strcpy(p->name, name);
            p->body.height = height;
            p->body.vision = vision;
        }
    }
    return p;
}

void PhysCheckDestroy(PhysCheck* x) {
    free(x->name);
    free(x);
}

bool PhysCheckEqual(const PhysCheck* a, const PhysCheck* b) {
    return strcmp(a->name, b->name) == 0;
}

void PhysCheckPrint(const PhysCheck* x) {
    printf("%s %f %d\n", x->name, x->body.vision, x->body.height);
}

typedef struct {
    int max; /* スタックの容量 */
    int ptr; /* スタックポインタ */
    PhysCheck** stk; /* スタック本体*/
} PhysCheckStack;

int Search(const PhysCheckStack* s, const PhysCheck* x) {
    int count = 0;
    for (int i = 0; i < s->ptr; i++) {
        if (PhysCheckEqual(s->stk[i], x)) {
            PhysCheckPrint(s->stk[i]);
            count++;
        }
    }
    return count;
}

int SearchByName(const PhysCheckStack* s, const char* name) {
    int count = 0;
    for (int i = 0; i < s->ptr; i++) {
        if (strcmp(s->stk[i]->name, name)) {
            PhysCheckPrint(s->stk[i]);
            count++;
        }
    }
    return count;
}

/*--- スタックの初期化 ---*/
bool Initialize(PhysCheckStack* s, int max) {
    s->stk = (PhysCheck**)calloc(max, sizeof(PhysCheck*));
    if (s->stk == NULL) {
        return false;
    }
    s->ptr = 0;
    s->max = max;
    return true;
}

/*--- スタックにデータをプッシュ ---*/
bool Push(PhysCheckStack* s, PhysCheck* x) {
    if (s->ptr >= s->max) return false; /* スタック満杯 */
    s->stk[s->ptr] = x;
    s->ptr++;
    return true;
}

/*--- スタックからデータをポップ ---*/
PhysCheck* Pop(PhysCheckStack* s) {
    if (s->ptr <= 0) return NULL; /* スタックは空 */
    s->ptr--;
    return s->stk[s->ptr];
}

/*--- スタックからデータをピーク ---*/
PhysCheck* Peek(PhysCheckStack* s) {
    if (s->ptr <= 0) return NULL;
    return s->stk[s->ptr - 1];
}

/*--- スタックの容量 ---*/
int Capacity(const PhysCheckStack* s) {
    return s->max;
}

/*--- スタックに積まれているデータ数 ---*/
int Size(const PhysCheckStack* s) {
    return s->ptr;
}

/*--- スタックの全データの表示 ---*/
void Print(const PhysCheckStack* s) {
    int i;

    for (i = 0; i < s->ptr; i++)
        PhysCheckPrint(s->stk[i]);
    putchar('\n');
}

/*--- スタックの廃棄 ---*/
void Terminate(PhysCheckStack* s) {
    while (Size(s) > 0) {
        PhysCheckDestroy(Pop(s));
    }
    free(s->stk);
}

int main(void) {
    PhysCheckStack s;
    Initialize(&s, 10);
    while (1) {
        int menu;
        double vision;
        int    height;
        char   name[50];
        PhysCheck* x;
        printf("現在のデータ数:%d/%d\n", Size(&s), Capacity(&s));
        printf("(1) プッシュ (2) ポップ (3) ピーク (4) 表示 (5) 探索 (0) 終了:");
        scanf("%d", &menu);
        if (menu == 0) break;
        switch (menu) {
        case 1: /* プッシュ */
        printf("データ(name vision height):");
        scanf("%s", name);
        scanf("%lf", &vision);
        scanf("%d", &height);
        x = PhysCheckCreate(name, vision, height);
        if (x == NULL || !Push(&s, x))
            puts("\a エラー:プッシュに失敗しました。");
        break;
        case 2: /* ポップ */
        x = Pop(&s);
        if (x == NULL) {
            puts("\a エラー:ポップに失敗しました。");
        }
        else {
            printf("ポップしたデータは");
            PhysCheckPrint(x);
            PhysCheckDestroy(x);
        }
        break;
        case 3: /* ピーク */
        x = Peek(&s);
        if (x == NULL) {
            puts("\a エラー:ピークに失敗しました。");
        }
        else {
            printf("ピークしたデータは");
            PhysCheckPrint(x);
        }
        break;
        case 4: /* 表示 */
        Print(&s);
        break;
        case 5://探索
        printf("検索する名前:");
        scanf("%s", name);
        int search = SearchByName(&s, name);
        if (search == 0) {
            puts("パターンは存在しません");
        }
        else {
            printf("%dパターンあります\n", search);
        }
        }
    }
    Terminate(&s);
    return 0;
}

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/06/06 11:08

    了解しました。

    キャンセル

  • 2020/06/06 21:40

    やってみたけどちぃと面倒になりますな...

    キャンセル

  • 2020/06/06 22:33

    ポインタについての理解が不足していたと反省したので一から教本読み直しています。。。

    キャンセル

-1

どこかでメモリ破壊してるとかアクセス違反してるとかなので、そういう怪しいところを探すべし

あなたにはまだポインタをどーこ~するのは早いので、まずはC言語の文法をしっかり学びましょう。
身の丈を超えて、質問回答繰り返しても理解できないでしょ。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る