紧张的卡多希 2022-04-16 10:06 采纳率: 68.4%
浏览 32
已结题

怎么把栈内输入元素的类型改为double

#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;
} }}

img

  • 写回答

1条回答 默认 最新

  • 陆海潘江小C 2020CSDN博客之星Top85 2022-04-16 10:52
    关注

    代码已经帮你修改,若有帮助,可以采纳,测试结果如下

    img

    
    #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;}
    

    若已解决,可以采纳

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月24日
  • 已采纳回答 4月16日
  • 修改了问题 4月16日
  • 创建了问题 4月16日

悬赏问题

  • ¥15 ansys fluent计算闪退
  • ¥15 有关wireshark抓包的问题
  • ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
  • ¥15 向数据表用newid方式插入GUID问题
  • ¥15 multisim电路设计
  • ¥20 用keil,写代码解决两个问题,用库函数
  • ¥50 ID中开关量采样信号通道、以及程序流程的设计
  • ¥15 U-Mamba/nnunetv2固定随机数种子
  • ¥15 vba使用jmail发送邮件正文里面怎么加图片
  • ¥15 vb6.0如何向数据库中添加自动生成的字段数据。