#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:
return 0;
}
}
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/jgYzotrPjgorjgb7jgZvjgpNcbiIpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgNToKICAgICAgICAgICAgc2NhbmYoIiVsZiIsICZudW0pOwogICAgICAgICAgICBwdXNoKG51bSk7CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgOToKCQkJcmV0dXJuIDA7CgogICAgICAgIH0KICAgIH0KCQoJYW5zd2VyKCk7CgogICAgcmV0dXJuIDA7Cn0KCnZvaWQgcHVzaChkb3VibGUgdmFsdWUpCnsKICAgIGlmICghaXNGdWxsKCkpIHsKICAgICAgICBzdGFja1tzcCsrXSA9IHZhbHVlOwogICAgfSBlbHNlIHsKICAgICAgICBwcmludGYoIuOCueOCv+ODg+OCr+OBjOa6gOadr+OBp+WFpeOCiuOBvuOBm+OCk+OBp+OBl+OBn1xuIik7CiAgICB9Cn0KCmRvdWJsZSBwb3Aodm9pZCkKewogICAgaWYgKCFpc0VtcHR5KCkpIHsKICAgICAgICByZXR1cm4gc3RhY2tbLS1zcF07CiAgICB9IGVsc2UgewogICAgICAgIHByaW50Zigi44K544K/44OD44Kv44GM56m644Gn5Y+W44KK5Ye644Gb44G+44Gb44KT44Gn44GX44GfXG4iKTsKICAgICAgICByZXR1cm4gMC4wOwogICAgfQp9CgppbnQgaXNGdWxsKHZvaWQpCnsKICAgIHJldHVybiBzcCA+PSBTSVpFOwp9CgppbnQgaXNFbXB0eSh2b2lkKQp7CiAgICByZXR1cm4gc3AgPD0gMDsKfQoKdm9pZCBhbnN3ZXIodm9pZCkKewogICAgaWYgKCFpc0VtcHR5KCkpIHsKICAgICAgICBwcmludGYoIuetlOOBiDogJWxmXG4iLCBzdGFja1tzcCAtIDFdKTsKICAgIH0gZWxzZSB7CiAgICAgICAgcHJpbnRmKCLjgrnjgr/jg4Pjgq/jgYznqbrjgafkvZXjgoLlj5bjgorlh7rjgZvjgb7jgZvjgpPjgafjgZfjgZ9cbiIpOwogICAgfQp9Cgp2b2lkIHJlc2V0KHZvaWQpCnsKICAgIHNwID0gMDsKfQo=