| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 256 人关注过本帖
标题:大哥求指导
只看楼主 加入收藏
huat107
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2012-11-18
结帖率:92.31%
收藏
已结贴  问题点数:10 回复次数:3 
大哥求指导
从键盘输入一个10进制的整数x和需要进行转换的进制n,输出x对应的n进制的数。例如,从键盘输入20和8,在数组b中应该是2   4
搜索更多相关主题的帖子: 键盘 
2012-11-25 11:27
一个孩子
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:356
专家分:954
注 册:2012-10-1
收藏
得分:7 
程序代码:
#include
#include
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
typedef struct
{
    int *top;
    int *base;
    int stacksize;
}sqstack;
int Initstack(sqstack &S)
{
    S.base=(int *)malloc(STACK_INIT_SIZE*sizeof(int));
    if(!S.base)
        return 0;
    S.top=S.base;
    S.stacksize=STACK_INIT_SIZE;
    return 1;

}
int Push(sqstack &S,int e)
{
    if(S.top-S.base>=S.stacksize)
    {
        S.base=(int *)realloc(S.base,(STACK_INIT_SIZE+STACKINCREMENT)*sizeof(int));
        if(!S.base)
            return 0;
        S.top=S.base+S.stacksize;
        S.stacksize+=STACKINCREMENT;
    }
    *S.top++=e;
    return 1;

}
int Pop(sqstack &S,int &e)
{
    if(S.top==S.base)
    {
        return 0;
    }
    e=*--S.top;
    return 1;
}
int IsEmpty(sqstack &S)
{
    if(S.top==S.base)
        return 1;
    else
        return 0;
}
int main()
{
    sqstack S;
    Initstack(S);
    int e;
    int m;
    int n;
    printf("please input a number!\n");
    scanf("%d",&m);
    printf("请输入你想要转换的进制数!\n");
    scanf("%d",&n);
    while(m)
    {
        Push(S,m%n);
        m=m/n;
    }
    while(!IsEmpty(S))
    {
        Pop(S,e);
        printf("%d ",e);
    }
    printf("\n");
    return 0;
}
以前写的,可以运行,如果是16进制的话,在输出的时候稍微改动下就可以了

重要的不是结果,是求一个结果的过程,哪怕千难万难,当你有想要的结果时,你已走的很远
2012-11-25 11:49
huat107
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2012-11-18
收藏
得分:0 
#include<stdio.h>
#define num 50
int main()
{
    int x,n,data[num]={0},index=0,i;
    printf("请输入一个十进制数和需要转的进制:");
    scanf("%d%d",&x,&n);
    do{
        if(x>0)
        {data[index]=x%n;
        x=x/n;
        index=index+1;}
        else
        {for(i=0;index>i;i++)
            printf("%d",data[index-i-1]);
            printf("\n");
            return 0;}
    }while(1);
return 0;
}

        
这样怎么逆序输出啊
2012-11-25 12:55
一个孩子
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:356
专家分:954
注 册:2012-10-1
收藏
得分:0 
肯定是逆序输出了,因为你数组存放的元素位置是逆序存放的,你想要顺序输出的话,只要逆序输出数组元素就可以了哦

重要的不是结果,是求一个结果的过程,哪怕千难万难,当你有想要的结果时,你已走的很远
2012-11-25 14:06
快速回复:大哥求指导
数据加载中...
 
   



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

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