[03a1] 値の逆順での出力

scanfで次々に正の整数を入力し、最後に0を入力すると、それまでに入 力された整数(最後の0は除く)が逆順に、1行に1つずつ出力されるよう なプログラムを作成せよ。出力には書式文字列 "%d\n" を用いる。 ただし配列機能や再帰は使わないこと。そのかわり、次のヘッダファイ ルistack.hが提供するスタック機能を呼び出して用いる。スタックサイ ズは100あれば十分であるものとする。

// istack.h
#include <stdbool.h>
struct istack;
typedef struct istack *istackp;
istackp istack_new(int size);
bool istack_isempty(istackp p);
void istack_push(istackp p, int v);
int istack_pop(istackp p);

参考までにテキスト掲載の実装は次の通り。

// istack.c --- int type stack impl. with array
#include <stdlib.h>
#include "istack.h"
struct istack { int ptr; int *arr; };
istackp istack_new(int size) {
  istackp p = (istackp)malloc(sizeof(struct istack));
  p->ptr = 0; p->arr = (int*)malloc(size * sizeof(int));
  return p;
}
bool istack_isempty(istackp p) { return p->ptr <= 0; }
void istack_push(istackp p, int v) { p->arr[p->ptr++] = v; }
int istack_pop(istackp p) { return p->arr[--(p->ptr)]; }
int istack_top(istackp p) { return p->arr[p->ptr - 1]; }

プログラムでは下請け関数は用いないこと。

記号列 

コード 

選択肢

ア #include <stdbool.h>
イ #include <stdio.h>
ウ #include <stdlib.h>
エ #include "istack.h"
オ int main(int argc, char *argv[]) {
カ return 0;
キ }
ク for(i = 2; i <= n; ++i) {
ケ for(i = 1; i < n; ++i) {
コ for(i = 0; i < n; ++i) {
サ if(i == 0) { break; }
シ if(i != 0) { break; }
ス while(!istack_isempty(s)) {
セ while(n % i == 0) {
ソ while(n % i != 0) {
タ while(true) {
チ int i, n;
ツ istack_push(s, i);
テ istackp s = istack_new(100);
ト n = atoi(argv[1]);
ナ n = n / i;
ニ printf("%d\n", istack_pop(s));
ヌ printf("i> "); scanf("%d", &i);

選択肢の行をドラグして上のコード領域に配置してください。 コード領域の行はドラグにより位置が変更できます。 削除したい場合は選択肢の領域に戻してください。