#include <stdio.h>
#define SIZE 10
double stack[SIZE];
int sp;
void push(double value);
double pop(void);
int isFull(void);
int isEmpty(void);
void answer(void);
void reset(void);
int main(void)
{
int cmd;
double a, b, num;
reset();
while (1)
{
switch (cmd)
{
case 1:
if (sp >= 2)
{
b = pop();
a = pop();
push(a + b);
}
else
{
}
break;
case 2:
if (sp >= 2)
{
b = pop();
a = pop();
push(a - b);
}
else
{
}
break;
case 3:
if (sp >= 2)
{
b = pop();
a = pop();
push(a * b);
}
else
{
}
break;
case 4:
if (sp >= 2)
{
b = pop();
a = pop();
if (b != 0)
push(a / b);
else
}
else
{
}
break;
case 5:
push(num);
break;
case 9:
answer();
return 0;
}
}
}
void push(double value)
{
if (!isFull()) {
stack[sp++] = value;
} else {
}
}
double pop(void)
{
if (!isEmpty()) {
return stack[--sp];
} else {
printf("スタックが空で取り出せませんでした\n"); return 0.0;
}
}
int isFull(void)
{
return sp >= SIZE;
}
int isEmpty(void)
{
return sp <= 0;
}
void answer(void)
{
if (!isEmpty()) {
printf("答え: %lf\n", stack
[sp
- 1]); } else {
printf("スタックが空で何も取り出せませんでした\n"); }
}
void reset(void)
{
sp = 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CgojZGVmaW5lIFNJWkUgMTAKZG91YmxlIHN0YWNrW1NJWkVdOwppbnQgc3A7Cgp2b2lkIHB1c2goZG91YmxlIHZhbHVlKTsKZG91YmxlIHBvcCh2b2lkKTsKaW50IGlzRnVsbCh2b2lkKTsKaW50IGlzRW1wdHkodm9pZCk7CnZvaWQgYW5zd2VyKHZvaWQpOwp2b2lkIHJlc2V0KHZvaWQpOwoKaW50IG1haW4odm9pZCkKewogICAgaW50IGNtZDsKICAgIGRvdWJsZSBhLCBiLCBudW07CgogICAgcmVzZXQoKTsKICAgIHdoaWxlICgxKQogICAgewogICAgICAgIHNjYW5mKCIlZCIsICZjbWQpOwoKICAgICAgICBzd2l0Y2ggKGNtZCkKICAgICAgICB7CiAgICAgICAgY2FzZSAxOgogICAgICAgICAgICBpZiAoc3AgPj0gMikgCgkJCXsKICAgICAgICAgICAgICAgIGIgPSBwb3AoKTsKICAgICAgICAgICAgICAgIGEgPSBwb3AoKTsKICAgICAgICAgICAgICAgIHB1c2goYSArIGIpOwogICAgICAgICAgICB9IAoJCQllbHNlIAoJCQl7CiAgICAgICAgICAgICAgICBwcmludGYoIuOCueOCv+ODg+OCr+OBjOi2s+OCiuOBvuOBm+OCk1xuIik7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgY2FzZSAyOgogICAgICAgICAgICBpZiAoc3AgPj0gMikgCgkJCXsKICAgICAgICAgICAgICAgIGIgPSBwb3AoKTsKICAgICAgICAgICAgICAgIGEgPSBwb3AoKTsKICAgICAgICAgICAgICAgIHB1c2goYSAtIGIpOwogICAgICAgICAgICB9IAoJCQllbHNlIAoJCQl7CiAgICAgICAgICAgICAgICBwcmludGYoIuOCueOCv+ODg+OCr+OBjOi2s+OCiuOBvuOBm+OCk1xuIik7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgY2FzZSAzOgogICAgICAgICAgICBpZiAoc3AgPj0gMikgCgkJCXsKICAgICAgICAgICAgICAgIGIgPSBwb3AoKTsKICAgICAgICAgICAgICAgIGEgPSBwb3AoKTsKICAgICAgICAgICAgICAgIHB1c2goYSAqIGIpOwogICAgICAgICAgICB9IAoJCQllbHNlIAoJCQl7CiAgICAgICAgICAgICAgICBwcmludGYoIuOCueOCv+ODg+OCr+OBjOi2s+OCiuOBvuOBm+OCk1xuIik7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgY2FzZSA0OgogICAgICAgICAgICBpZiAoc3AgPj0gMikgCgkJCXsKICAgICAgICAgICAgICAgIGIgPSBwb3AoKTsKICAgICAgICAgICAgICAgIGEgPSBwb3AoKTsKICAgICAgICAgICAgICAgIGlmIChiICE9IDApCiAgICAgICAgICAgICAgICAgICAgcHVzaChhIC8gYik7CiAgICAgICAgICAgICAgICBlbHNlCiAgICAgICAgICAgICAgICAgICAgcHJpbnRmKCIw44Gn5Ymy44KM44G+44Gb44KTXG4iKTsKICAgICAgICAgICAgfSAKCQkJZWxzZSAKCQkJewogICAgICAgICAgICAgICAgcHJpbnRmKCLjgrnjgr/jg4Pjgq/jgYzotrPjgorjgb7jgZvjgpNcbiIpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgNToKICAgICAgICAgICAgc2NhbmYoIiVsZiIsICZudW0pOwogICAgICAgICAgICBwdXNoKG51bSk7CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgOToKCQkJYW5zd2VyKCk7CgkJCXJldHVybiAwOwoKICAgICAgICB9CiAgICB9CgkKfQoKdm9pZCBwdXNoKGRvdWJsZSB2YWx1ZSkKewogICAgaWYgKCFpc0Z1bGwoKSkgewogICAgICAgIHN0YWNrW3NwKytdID0gdmFsdWU7CiAgICB9IGVsc2UgewogICAgICAgIHByaW50Zigi44K544K/44OD44Kv44GM5rqA5p2v44Gn5YWl44KK44G+44Gb44KT44Gn44GX44GfXG4iKTsKICAgIH0KfQoKZG91YmxlIHBvcCh2b2lkKQp7CiAgICBpZiAoIWlzRW1wdHkoKSkgewogICAgICAgIHJldHVybiBzdGFja1stLXNwXTsKICAgIH0gZWxzZSB7CiAgICAgICAgcHJpbnRmKCLjgrnjgr/jg4Pjgq/jgYznqbrjgaflj5bjgorlh7rjgZvjgb7jgZvjgpPjgafjgZfjgZ9cbiIpOwogICAgICAgIHJldHVybiAwLjA7CiAgICB9Cn0KCmludCBpc0Z1bGwodm9pZCkKewogICAgcmV0dXJuIHNwID49IFNJWkU7Cn0KCmludCBpc0VtcHR5KHZvaWQpCnsKICAgIHJldHVybiBzcCA8PSAwOwp9Cgp2b2lkIGFuc3dlcih2b2lkKQp7CiAgICBpZiAoIWlzRW1wdHkoKSkgewogICAgICAgIHByaW50Zigi562U44GIOiAlbGZcbiIsIHN0YWNrW3NwIC0gMV0pOwogICAgfSBlbHNlIHsKICAgICAgICBwcmludGYoIuOCueOCv+ODg+OCr+OBjOepuuOBp+S9leOCguWPluOCiuWHuuOBm+OBvuOBm+OCk+OBp+OBl+OBn1xuIik7CiAgICB9Cn0KCnZvaWQgcmVzZXQodm9pZCkKewogICAgc3AgPSAwOwp9Cg==