ViVi Home > 技術文書 > ポインタ入門 > ポインタ穴埋め問題集


 
Follow @vivisuke Tweet

 

ポインタ穴埋め問題集 は C/C++ のポインタを学習するため問題集です。
入力エリアに適切な(半角)文字列を入力し、画面下部の【採点】を押してください。
※ sizeof(void*) は 4、sizeof(int) は 4、sizeof(short) は 2 とする。
※ 文字エンコーディングは ASCII 、文字列は '\0' を終端とする。
※ バイトオーダはリトルエンディアンとする。
※ 文字列領域は充分な領域が確保されているものとする。
※ 特に指示が無い限り、ポインタが指す構造体のメンバを参照する場合は (*ptr).mbr ではなく ptr->mbr と記述しなさい。

Q1: 文字列をコピーする関数を完成させなさい。
void strcpy(char *dst, const char *src)
{
    while( (*++ = *++) != '\0' ) ;
}


Q2: 動的配列クラスのコンストラクタ、デストラクタを完成させなさい。
class Vector {
    enum {
        INI_SIZE = 8,
    };
public:
    Vector()
      : m_size(0)
      , m_capacity(INI_SIZE)
      , m_data( int[INI_SIZE])
    {
    }
    ~Vector()
    {
        delete ;
    }
private:
    int    *m_data;// アロケートされたデータ領域へのポインタ
    int    m_size;   // データ領域に入っている要素数
    int    m_capacity;// アロケートされたデータ領域サイズ、初期値:8
};


Q3: 文字数を数える関数を完成させなさい。
int strlen(const char *str)
{
    int len = 0;
    while( *str++  '\0' ) {
        ++;
    }
    return len;
}


Q4: 環状双方向リンクリストの末尾ノードを返す関数を完成させなさい
struct Node {
    int    m_value; // ノードの値
    Node    *m_prev;// 前のノードへのポインタ
    Node    *m_next;// 次のノードへのポインタ
};
Node *lastNode(Node *root)  // root は環状双方向リンクリストの先頭ノードを指している
{
    return ->;
}


Q5: int へのポインタを宣言し、変数 x のアドレスで初期化するコードを完成させなさい。
int x = 0;
int  ptr = x;




※ 問題は5問ランダムに表示されます。 総問題数:42
※ 問題・解答に間違いがあった場合は、ツイッター or メール等でご指摘してくださると助かります。

最近10人の平均点:2.3
0 0 0 4 10 2 2 0 0 5 (latest)
最近100人の平均点:1.9
最近1000人の平均点:4.1
過去全部(5381人)の平均点:4.2

満点獲得者名と記念コメント:
24/11/22 00:07 名無し さん
24/11/19 06:05 名無し さん
24/11/12 16:41 名無し さん
24/11/12 07:40 名無し さん
24/11/08 23:43 名無し さん
24/11/08 18:06 名無し さん
24/11/08 00:25 名無し さん
24/11/05 02:51 名無し さん
24/11/04 12:01 名無し さん
24/11/02 17:49 名無し さん
24/10/31 01:50 名無し さん
24/10/28 23:24 名無し さん
24/10/28 14:32 名無し さん
24/10/26 09:55 名無し さん
24/10/26 07:06 名無し さん
24/10/23 21:08 名無し さん
24/10/22 17:45 名無し さん
24/10/19 21:10 名無し さん
24/10/19 19:24 名無し さん
24/10/17 14:24 名無し さん

Copyright (C) 2014 by N.Tsuda, All Rights Reserved.