📜  门| GATE-CS-2015(Set 2)|第48章

📅  最后修改于: 2021-06-29 04:59:05             🧑  作者: Mango

考虑下面的C程序。

#include 
int *A, stkTop;
int stkFunc (int opcode, int val)
{
    static int size=0, stkTop=0;
    switch (opcode)
    {
    case -1:
        size = val;
        break;
    case 0:
        if (stkTop < size ) A[stkTop++]=val;
        break;
    default:
        if (stkTop) return A[--stkTop];
    }
    return -1;
}
int main()
{
    int B[20];
    A=B;
    stkTop = -1;
    stkFunc (-1, 10);
    stkFunc (0, 5);
    stkFunc (0, 10);
    printf ("%d\n", stkFunc(1, 0)+ stkFunc(1, 0));
}

上面程序打印的值是___________
(A) 9
(B) 10
(C) 15
(D) 17答案: (C)
说明: main中的代码基本上初始化大小为10的堆栈,然后按5,然后按10。

最后,printf语句打印两个弹出操作的总和,即10 + 5 = 15。

stkFunc (-1, 10);   // Initialize size as 10
    stkFunc (0, 5);    // push 5
    stkFunc (0, 10);   // push 10

    // print sum of two pop
    printf ("%d\n", stkFunc(1, 0) + stkFunc(1, 0));

这个问题的测验