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

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

ただいまの
回答率

87.60%

C言語 スタック 一組の文字列を一スタックとしたい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,146

score 18

#include <stdio.h>
#define MAX 10
/*--- int 型スタックを実現する構造体 ---*/
/*--- 身体データ型 ---*/
typedef struct{
    int height; /* 身長 */
    double vision; /* 視力 */
} Body ;
/*--- 身体検査データ型 ---*/
typedef struct{
    Body body; /* 身体データ型 ---*/
    int ptr;/* スタックポインタ */
    int max;
    int stk[MAX];
    char name[20]; /* 氏名  20人分の箱*/
} PhysCheckStack ;

/*--- スタックの初期化 ---*/
int Initialize(PhysCheckStack *s, int max){
    s->ptr = 0;
    s->max = max;
    //s->max = ( sizeof s->name / sizeof s->name[0]);
    return 0;
}
/*--- スタックにデータをプッシュ ---*/
int Push(PhysCheckStack *s, char x[]){
    if (s->ptr >= s->max) return -1; /* スタック満杯 */
    for(int i = 0 ; x[i] != NULL ; i ++){
        s->name[s->ptr] = x[i];
        s->ptr++;
    }
    return 0;
}
// /*--- スタックからデータをポップ ---*/
// int Pop(PhysCheckStack *s, int *x){
//  if (s->ptr <= 0) return -1; /* スタックは空 */
//  s->ptr--;
//  *x = s->stk[s->ptr];
//  return (0);
// }
// /*--- スタックからデータをピーク ---*/
// int Peek(PhysCheckStack *s, int *x){
//  if (s->ptr <= 0) return -1;
//  *x = s->stk[s->ptr - 1];
//  return 0;
// }
/*--- スタックの容量 ---*/
int Capacity(const PhysCheckStack *s){
    return s->max;
}
// /*--- スタックに積まれているデータ数 ---*/
int Size(const PhysCheckStack *s){
    return  ;
}
/*--- スタックの全データの表示 ---*/
void Print(const PhysCheckStack *s){

    for(int i = 0; s->name[i] != NULL; i++) {
        printf("%s", s->name[i]);
    }
    putchar('\n');
}
int main(void){
    PhysCheckStack s;
    Initialize(&s, MAX);
    while (1) {
        int menu;
        char y[20];
        printf("現在のデータ数:%d/%d\n",Size(&s), Capacity(&s));
        printf("(1) プッシュ (2) ポップ (3) ピーク (4) 表示 (0) 終了:");
        scanf("%d", &menu);
        if (menu == 0) break;
        switch (menu) {
        case 1: /* プッシュ */
            printf("データ:");
            scanf("%s", y);
            if (Push(&s, y) == -1)
                puts("\a エラー:プッシュに失敗しました。");
            break;
            //  case 2: /* ポップ */
            //  if (Pop(&s, &x) == -1)
            //  puts("\a エラー:ポップに失敗しました。");
            //  printf("ポップしたデータは%d です。\n", x);
            //  break;
            //  case 3: /* ピーク */
            //  if (Peek(&s, &x) == -1)
            //  puts("\a エラー:ピークに失敗しました。");
            //  else
            //  printf("ピークしたデータは%d です。\n", x);
            //  break;
        case 4: /* 表示 */
            Print(&s);
            break;
        }
    }
    return 0;
}


開発途中段階です
1.プッシュで入力をabcとしたとき、現在のデータ数は1/10としたい
2.Print(&s);を呼び出したとき、abcと表示させたい

この解決プロセスについてアドバイスをよろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • maisumakun

    2020/06/01 16:55

    今のコードだと、どのような問題があるのでしょうか。

    (あと、インデントがなくて見づらいので追加していただければと思います)

    キャンセル

  • junnnnchan

    2020/06/01 17:06

    試行錯誤して出た値が、core dumpと出ました

    キャンセル

  • y_waiwai

    2020/06/01 17:15

    > 現在のデータ数は1/10としたい

    ってのが意味わかりませんが、どういうことでしょうか

    キャンセル

  • fana

    2020/06/01 17:18

    Size()がまともに実装されてないように見えますが…?

    キャンセル

回答 2

checkベストアンサー

0

これでいい?

#define _CRT_SECURE_NO_WARNINGS /* disable warning for VC++ */
#include <stdio.h>  // printf, puts, scanf
#include <stdlib.h> // malloc, free
#include <string.h> // strlen, strcpy
#include <assert.h>

char* string_duplicate(const char* str) {
  char* p = (char*)malloc(strlen(str)+1);
  if ( p ) strcpy(p, str);
  return p;
}

typedef struct {
    int max;
    int ptr;
    char** stk;
} PhysCheckStack;

/*--- スタックの初期化 ---*/
int Initialize(PhysCheckStack* s, int max) {
    assert( s != NULL);
    assert( max > 0 );
    s->stk = (char**)malloc(sizeof(char*) * max);
    if ( s->stk == NULL ) return -1;
    s->ptr = 0;
    s->max = max;
    return 0;
}

/*--- スタックにデータをプッシュ ---*/
int Push(PhysCheckStack* s, const char* x) {
    assert(s != NULL);
    assert(x != NULL);
    if (s->ptr >= s->max) return -1; /* スタック満杯 */
    s->stk[s->ptr] = string_duplicate(x);
    s->ptr++;
    return 0;
}

int Pop(PhysCheckStack *s, char** x) {
    assert(s != NULL);
    assert(x != NULL);
    if (s->ptr <= 0) return -1; /* スタックは空 */
    s->ptr--;
    *x = s->stk[s->ptr];
    return 0;
}

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

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

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

/*--- スタックの全データの表示 ---*/
void Print(const PhysCheckStack* s) {
    assert(s != NULL);
    for (int i = 0; i < s->ptr; ++i ) {
        printf("%s ", s->stk[i]);
    }
    putchar('\n');
}

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

int main(void) {
    PhysCheckStack s;
    Initialize(&s, 10);
    while (1) {
        int menu;
        char y[20];
        char* x;
        printf("現在のデータ数:%d/%d\n", Size(&s), Capacity(&s));
        printf("(1) プッシュ (2) ポップ (3) ピーク (4) 表示 (0) 終了:");
        scanf("%d", &menu);
        if (menu == 0) break;
        switch (menu) {
        case 1: /* プッシュ */
            printf("データ:");
            scanf("%s", y);
            if (Push(&s, y) == -1)
                puts("\a エラー:プッシュに失敗しました。");
            break;
        case 2: /* ポップ */
            if (Pop(&s, &x) == -1)
            puts("\a エラー:ポップに失敗しました。");
            printf("ポップしたデータは%s です。\n", x);
            free(x);
            break;
        case 3: /* ピーク */
            if (Peek(&s, &x) == -1)
                puts("\a エラー:ピークに失敗しました。");
            else
              printf("ピークしたデータは%s です。\n", x);
            break;
        case 4: /* 表示 */
            Print(&s);
        break;
        }
    }
    Terminate(&s);
    return 0;
}

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/06/02 12:27

    そうなんですか!
    最初は頭の中の定石を増やす作業をしたほうが良いのでしょうか?

    キャンセル

  • 2020/06/02 12:30

    人によりけりじゃないかしら。
    てか、定石なんてものはおベンキョしてるうちに自然と溜まるもんでしょ。
    溜まってないとしたら、おベンキョしてない/考えてない/身に付いてないってことじゃないかしらね。

    キャンセル

  • 2020/06/02 12:38

    もっと時間をかけて勉強すべきということですね!
    ありがとうございました。

    キャンセル

0

    for(int i = 0 ; x[i] != NULL ; i ++){
        s->name[s->ptr] = x[i];
        s->ptr++;
    }

s->nameはいったいなんなのか考えてみよう
添字の意味は?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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