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


 
Follow @vivisuke Tweet

 

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

Q1: first から last の直前までポインタが指すデータの最大値返す関数を完成させなさい。
int my_max(const int *first, const int *last)
{
    int val = INT_MIN;
    while( first != last ) {
        val = std::(, val);
    }
    return val;   // 最大値を返す
}


Q2: 文字列内の文字の順序を反転("abcd"→"dcba")する関数を完成させなさい。
void my_strrev(char *str)
{
    int len = strlen(str);
    char *ptr = str + len;  // 末尾を指すポインタを用意
    for(int i = 0; i < len/2; ++i) {  //      len の半分の回数ループ
        char t = ;
        *ptr = ;
        *str++ = t;
    }
}


Q3: 文字列末尾文字を取り出す関数を完成させなさい。ただし、文字列が空の場合は '\0' を返すものとする。
char pop_back(char *str)
{
    if ( == '\0') return '\0';
    while (*str != '\0') {
        ++str;
    }
    char c = *;
    *str = '\0';
    return c;
}


Q4: first から last の直前までポインタが指すデータを合計した値を返す関数を完成させなさい。
int my_accumulate(const int *first, const int *last)
{
    int sum = 0;
    while( first != last ) {
         += ;
    }
    return sum; // 合計値を返す
}


Q5: 2分木が、左側のノードの値 ≦ ノードの値 ≦ 右側のノードの値 となるようにソートされている時、ノードの値を小さい順に表示する関数を完成させなさい。
struct Node {
    int        m_value; // ノードの値
    Node    *m_lhs;   // 左側ノードへのポインタ
    Node    *m_rhs;  // 右側ノードへのポインタ
};
void print(const Node *ptr)
{
    if (ptr == 0) {
        ;
    }
    print(ptr->m_lhs);
    std::cout <<  << "\n";
    print(ptr->m_rhs);
}




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

最近10人の平均点:9.0
9 8 9 9 7 9 10 10 9 10 (latest)
最近100人の平均点:3.9
最近1000人の平均点:4.1
過去全部(5418人)の平均点:4.2

満点獲得者名と記念コメント:
25/01/18 07:22 名無し さん
25/01/18 04:38 名無し さん
25/01/17 10:16 名無し さん
25/01/14 15:05 名無し さん
25/01/14 06:28 名無し さん
25/01/13 23:54 名無し さん
25/01/13 22:55 名無し さん
25/01/11 10:16 名無し さん
25/01/10 00:08 名無し さん
25/01/09 02:23 名無し さん
25/01/08 16:24 名無し さん
25/01/06 08:44 名無し さん
25/01/04 15:42 名無し さん
25/01/04 08:49 名無し さん
25/01/02 02:43 名無し さん
24/12/30 22:55 名無し さん
24/12/28 02:08 名無し さん
24/12/23 09:41 名無し さん
24/12/20 15:40 名無し さん
24/12/08 04:20 名無し さん

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