| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1565 人关注过本帖
标题:解答下啊,高手啊
取消只看楼主 加入收藏
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
 问题点数:0 回复次数:6 
解答下啊,高手啊
#include<stdio.h>
#define Maxsize 30
typedef struct
{
    int s[Maxsize];
    int *top;
    int *base;
}stack;
void initstack(stack *st)
{
    st->top=st->base;
}
int push(stack *st,int x)
{
    if(st->top-st->base>=Maxsize-1)
        return 0;
    else
    {
        *(st->top++)=x;
        return 1;
    }
}
int stackempty(stack st)
{
    if(st.top==st.base)
        return 1;
    else return 0;
}
int pop(stack *st,int x)
{
    if(st->top==st->base)
        return 0;
    else
    {
        x=--(*st->top);
        st->top--;
        return 1;
    }
}
void main()
{
    stack st;
    initstack(&st);
    int n;
    scanf("%d",&n);
    while(n)
    {
        push(&st,n%2);
        n=n/2;
    }
    while(!stackempty(st))
    {
        int e;
        pop(&st,e);
        printf("%d",e);
    }
}
搜索更多相关主题的帖子: 解答 
2008-04-06 18:49
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
得分:0 
我知道错哪会问你吗?你不会运行下啊,不比我告诉你强啊。
说话这么不客气,虽然我有求与你,你的话,真的听了不舒服。
2008-04-08 14:24
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
得分:0 
鄙视,你也去死吧。
2008-04-08 15:06
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
得分:0 
ok,I know.Thank you.
2008-04-09 20:42
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
得分:0 
//自己顶下,改过的
#include<stdio.h>   
#include<malloc.h>
#define Maxsize 30   

#define stack_init_size 100
#define stackincrement 20

typedef struct      
{
    int s[Maxsize];
    int *top;
    int *base;
}stack;

void initstack(stack *st)   
{
    (*st).base=(int *)malloc(stack_init_size*sizeof(int));
    (*st).top=(*st).base;
}

int push(stack *st,int x)  
{
        *st->top++=x;
    
        return 1;

}

int stackempty(stack st)   
{
    return(st.top==st.base);
}

int pop(stack *st,int *x)  
{
        *x=*--(*st).top;
        return 1;

}

void main()
{
    stack st;
    st.base=st.top=0;   
    initstack(&st);  
    int n;     
    scanf("%d",&n);
    while(n)
    {
        push(&st,n%2);
        n=n/2;
    }
    while(!stackempty(st))
    {
        int e;
        pop(&st,&e);
        printf("%d",e);
    }
    printf("\n");
}
2008-04-12 18:10
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
得分:0 
我已经有说过知道了,孔明先生。这贴真是我生命中的败笔。
知道错的人,你就别再攻击了吧。
2008-04-12 18:28
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
收藏
得分:0 
姐姐,你可爱了啊。我应该怎么认罪呢?
2008-04-13 20:31
快速回复:解答下啊,高手啊
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016124 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved