#include<stdio.h>
#define MAXN 10
int push(int *stack,int maxn,int *toppt,int x) //进栈函数
{if(*toppt>=maxn)
return 1;
stack[*toppt]=x;
++(*toppt);
return 0;}
int pop(int *stack,int *toppt,int *cp) //出栈函数
{
if(*toppt==0)
return 1;
--(*toppt);
*cp=stack[*toppt];
return 0;
}
void outputstack(int *stack,int toppt) //输出栈元素
{
int i;
for(i=toppt-1;i>=0;i--)
printf("%c",stack[i]);
printf("\n");
}
void main()
{
int s[MAXN],i;
int top=0;
int op;
while(1)
{
printf("请选择操作,1:进栈 2:出栈 0:退出\n");
scanf("%d",&op);
switch(op){
case 0: return;
case 1:
printf("请输入进栈元素:");
scanf("\n");
scanf("%c",&i);
if(push(s,MAXN,&top,i)==0){
printf("进栈成功,栈内元素为:\n");
outputstack(s,top);}
else
printf("栈满\n");
break;
case 2:
if(pop(s,&top,&i)==0){
printf("出栈元素为:[%c],栈内元素为:\n",i);
outputstack(s,top);}
else
printf("栈空\n");
break;
} }}

怎么把栈内输入元素的类型改为double
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
关注
代码已经帮你修改,若有帮助,可以采纳,测试结果如下
#include<stdio.h> #define MAXN 10 double push(double *stack,int maxn,int *toppt,double x) //进栈函数 {if(*toppt>=maxn) return 1; stack[*toppt]=x; ++(*toppt); return 0;} double pop(double *stack,int *toppt,double *cp) //出栈函数 { if(*toppt==0) return 1; --(*toppt); *cp=stack[*toppt]; return 0; } void outputstack(double *stack,int toppt) //输出栈元素 { int i; for(i=toppt-1;i>=0;i--) printf("%lf",stack[i]); printf("\n"); } int main() { double s[MAXN]; double i; int top=0; int op; while(1) { printf("请选择操作,1:进栈 2:出栈 0:退出\n"); scanf("%d",&op); switch(op){ case 0: return 0; case 1: printf("请输入进栈元素:"); scanf("\n"); scanf("%lf",&i); if(push(s,MAXN,&top,i)==0){ printf("进栈成功,栈内元素为:\n"); outputstack(s,top);} else printf("栈满\n"); break; case 2: if(pop(s,&top,&i)==0){ printf("出栈元素为:[%lf],栈内元素为:\n",i); outputstack(s,top);} else printf("栈空\n"); break; } } return 0;}
若已解决,可以采纳
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用