任意进制转换
发布日期:2021-06-29 14:39:27
浏览次数:2
分类:技术文章
本文共 1165 字,大约阅读时间需要 3 分钟。
//群:970353786#include "stdio.h"#includeusing namespace std;#define StackSize 100typedef char ElemType;typedef struct{ ElemType data[StackSize]; int top;}SqStack;int trans(int d, int b, char string[]) //string用于存放转换后的字符串{ SqStack st; char ch; int r, i = 0; st.top = -1; // 栈初始化 if (b <= 1 || b > 36 || b == 10) // 2≤b≤36且不为10 { printf_s(" b is Error\n"); return 0; } while (d != 0)//辗转相除法 { r = d % b; //求余数 ch = r + (r < 10 ? '0' : 'A' - 10); // 将余数转换为相应的字符 st.top++; st.data[st.top] = ch; // 进栈 d /= b; } while (st.top != -1) { string[i++] = st.data[st.top]; //将出栈的字符放入字符数组string st.top--; } string[i] = '\0'; //加入字符串结束标志 return 1;}void main(){ while (1) { char str[10]; int d, b, t; printf_s("请输入整数:"); //请输入待转换的整数 scanf_s("%d", &d); printf("请输入要转换为几进制:"); // 请输入待转换的进制 scanf_s("%d", &b); t = trans(d, b, str); // 调用进制转换函数 cout << "进制转换结果为:"; if (t == 0) printf("Error!"); else printf("%s\n", str); // 输出转换结果字符串 }}
转载地址:https://chuanchuan.blog.csdn.net/article/details/116906256 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2024年04月09日 07时39分30秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
【Scala 教程】Scala 模式匹配与异常处理
2019-04-29
JAVA 线程休眠 sleep 与 线程礼让 yield
2019-04-29
JAVA Lock锁
2019-04-29
JAVA 线程同步机制 synchronized
2019-04-29
MySQL 安装教程(无脑版)
2019-04-29
JAVA 简单实现UDP demo
2019-04-29
MySQL 事务--转账
2019-04-29
JAVA UDP简单实现实时发送消息
2019-04-29
IDEA 怎么删除一个Module
2019-04-29
JAVA 和MySQL使用JDBC连接
2019-04-29
JAVA 反射的性能测试
2019-04-29
HTML 初探
2019-04-29
成功关键在于此:如何创造一个有即时价值的最小化可行产品?
2019-04-29
终端大改造:只需五步,构建你的梦中情“端”
2019-04-29
你的代码“balance”怎么样?找到简洁性和可读性的平衡点
2019-04-29
中科院刘康:低资源环境下的事件知识抽取
2019-04-29
提高软件工程技能的关键技术,这些资源赶紧收藏起来
2019-04-29
走进数据科学:最好是通过比网课更好的方法
2019-04-29
机器学习背后的数学支柱,这5本书帮你搞定!
2019-04-29
AI革命第一步:最容易被忽略但必不可少的物联网
2019-04-29