数据结构实验之栈与队列一:进制转换

Problem Description
输入一个十进制非负整数,将其转换成对应的 R (2 <= R <= 9) 进制数,并输出。

Input
第一行输入需要转换的十进制非负整数;
第二行输入 R。

Output
输出转换所得的 R 进制数。

Sample Input
1279
8
Sample Output
2377
题解:
将十进制数转化为其他进制的数时,需要不断地除以需要转化的进制直到商为零然后把所得的余数倒过来就是转化成的R进制数,在用栈实现时需要不断地用这个十进制数去除以它需要转化的进制,把得到的余数储存到栈里,直到商为零,再把栈里面储存的数字输出,我们知道栈有先进后出的特点,因此再输出的数字就是余数倒过来的效果,就得到了最终的答案。

#include <stdio.h>
#include <stdlib.h>
#define stackinitsize 100
#define stackcreat 10
#define ok 1
#define overflow -1
#define error -1
typedef int elemtype;
typedef struct
{
    elemtype *base;
    elemtype *top;
    int stacksize;

} sqstack;
int initstack(sqstack *s)
{
    s->base=(elemtype*)malloc(stackinitsize*sizeof(elemtype));
    if(!s->base)exit(overflow);
    s->top=s->base;
    s->stacksize=stackinitsize;
    return ok;

}
int push(sqstack *s,elemtype e)
{
    if(s->top-s->base>=s->stacksize)
    {
        s->top=(elemtype*)realloc(s->base,(s->stacksize+stackcreat)*sizeof(elemtype));
        if(!s->base)exit(overflow);
        s->top=s->base+s->stacksize;
    }
    *s->top++=e;
    return ok;

}
int pop(sqstack *s)
{
    if(s->top==s->base)return error;
    s->top--;
    return ok;

}
int stackempty(sqstack *s)
{
    if(s->top==s->base)return 1;
    else return 0;

}
int gettop(sqstack *s)
{
    int e;
    if(s->top==s->base)return error;
    e=*(s->top-1);
    return e;
}
int main()
{
    int n,r,e;
    sqstack s;
    scanf("%d",&n);
    scanf("%d",&r);
    if(n==0)printf("0\n");//注意如果被除数为零,则都是零
    initstack(&s);
    while(n)//不断相除,将余数存到栈里面
    {
        push(&s,n%r);
        n=n/r;


    }
    while(!stackempty(&s))//当栈不空的时候,把栈里面的数字输出
    {
        e=gettop(&s);
        pop(&s);
        printf("%d",e);

    }

    printf("\n");

    return 0;
}

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用栈和队列实现进制转换的C语言代码: 栈的实现: ```c #include <stdio.h> #define MAX_STACK 100 int stack[MAX_STACK_SIZE]; int top = -1; void push(int item) { if (top >= MAX_STACK_SIZE - 1) { printf("Stack Overflow!\n"); return; } stack[++top] = item; } int pop() { if (top == -1) { printf("Stack Underflow!\n"); return -1; } return stack[top--]; } int is_empty() { return top == -1; } ``` 队列实现: ```c #include <stdio.h> #define MAX_QUEUE_SIZE 100 int queue[MAX_QUEUE_SIZE]; int front = 0; int rear = 0; void enqueue(int item) { if ((rear + 1) % MAX_QUEUE_SIZE == front) { printf("Queue Overflow!\n"); return; } queue[rear] = item; rear = (rear + 1) % MAX_QUEUE_SIZE; } int dequeue() { if (front == rear) { printf("Queue Underflow!\n"); return -1; } int item = queue[front]; front = (front + 1) % MAX_QUEUE_SIZE; return item; } int is_empty() { return front == rear; } ``` 进制转换函数: ```c #include <stdio.h> void convert(int num, int base) { int rem; while (num != 0) { rem = num % base; // 求余数 push(rem); // 将余数入栈 num /= base; // 更新被除数 } while (!is_empty()) { enqueue(pop()); // 将栈中的元素出栈并入队列 } while (!is_empty()) { printf("%d", dequeue()); // 依次出队列并输出 } printf("\n"); } int main() { int num, base; printf("Enter a number: "); scanf("%d", &num); printf("Enter the base: "); scanf("%d", &base); printf("The converted number is: "); convert(num, base); return 0; } ``` 在该程序中,我们首先输入一个要转换的数字和目标进制,接着调用 `convert` 函数,该函数使用栈来存储余数,然后将余数依次出栈并入队列,最后依次出队列并输出,即可实现进制转换

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值