进制转换【野路子改造】

非科班,一直都是自己的野路子,现在要回炉重造

十进制->二进制

基本思想:

开始写的(80%):

#include<stdio.h>
using namespace std;
int main(){
int n;
scanf("%d",&n);
int a[10];
int i=0;
do
{a[i++]=n%2;n/=2;
}while(n!=0);
for (int j=i-1;j>=0;j--)
printf("%d",a[j]);}

 1024=2^10,需要a[11]

把a[10]改成a[11](100%)

#include<stdio.h>
using namespace std;
int main(){
int n;
scanf("%d",&n);
int a[11];
int i=0;
do
{a[i++]=n%2;n/=2;
}while(n!=0);
for (int j=i-1;j>=0;j--)
printf("%d",a[j]);}

十进制->k进制:

 

 注意:

可能会是字母!

#include<stdio.h>
using namespace std;
int main(){
int n,k;
char a[11];
char b[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
scanf("%d %d",&n,&k);
int i=0;
do
{a[i++]=b[n%k];n/=k;
}while(n!=0);
for (int j=i-1;j>=0;j--)
printf("%c",a[j]);}

上面的做法太蠢了。输出端可用if (数字)else(字母);

再加上字符串是连着的,printf("%c",'A'+1)等于printf("%c",'B');

所以可以

for (int i = len - 1; i >= 0; i--) {if (radixK[i] <= 9) {printf("%d", radixK[i]);} else {printf("%c", radixK[i] - 10 + 'A');}}

注意:char的输出用%c,不能用%s。 

2进制转十进制

思路

k进制转10进制

Q1:如何接受输入? 

Q2:如何知道输入长度?

A2:一个一个字符char的接受赋值给c[i];i++

 

A1:看i

我写的(ac)

#include<stdio.h>
#include<string>
using namespace std;
int main(){char c[8]; char input1;int c2[8];int ci2=0;int i=0;int k;do
{scanf("%c",&input1);if (input1>='0' && input1<='9')c2[i++]=input1-'0';else
{if (input1>='A' && input1<='F')c2[i++]=input1-'A'+10;
}}while(input1!=' ');
scanf("%d",&k);
//printf("%d",k);
int ans=0;
for (int j=0;j<i;j++)
{
//printf("%d",c2[j]);
ans=ans*k+c2[j];
//printf("--%d--",ans);}
printf("%d",ans);}

我的代码有个bug,就是输入只能用空格隔开,一旦用回车,就会出错

当然下面这位也是 ,但下面这位可以修改

标准答案:

#include <cstdio>
#include <cstring>const int MAXN = 8;
char radixK[MAXN];int main() {int k;scanf("%s %d", radixK, &k);int radix10 = 0, base = 1, lenRadixK = strlen(radixK);for (int i = lenRadixK - 1; i >= 0; i--) {int thisPosition = (radixK[i] >= '0' && radixK[i] <= '9') ? (radixK[i] - '0') : (radixK[i] - 'A' + 10);radix10 += thisPosition * base;base *= k;}printf("%d", radix10);return 0;
}

·A1:【include cstring】使用了cstring,与%d用空格隔开

A2:strlen获取字符串长度

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/15182.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring -- DI

文章目录 一、什么是DI二、注入的三种方式2.1 属性注入 Autowired使用方法Autowired存在的问题以及解决方法Autowired问题的解决方法 2.2 构造方法注入2.3 setter方法注入2.4 三种注入方式优缺点分析 一、什么是DI 概念&#xff1a;DI(依赖注入)就是当我们把依赖对象取出来(创…

以太坊钱包

以太坊钱包是你通往以太坊系统的门户。它拥有你的密钥&#xff0c;并且可以代表你创建和广播交易。选择一个以太坊钱包可能很困难&#xff0c;因为有很多不同功能和设计选择。有些更适合初学者&#xff0c;有些更适合专家。即使你现在选择一个你喜欢的&#xff0c;你可能会决定…

mac m1 pcre.h 找不到

安装suricata报错&#xff1a; configure: error: pcre.h not found ... 解决&#xff1a; brew install pcre 找到这个文件的地址 brew list pcre | grep pcre.h$ /opt/homebrew/Cellar/pcre/8.45/include/pcre.h 程序搜索的地址 cpp -v /Library/Developer/CommandLineT…

5.26 基于UDP的网络聊天室

需求&#xff1a; 如果有人发送消息&#xff0c;其他用户可以收到这个人的群聊信息 如果有人下线&#xff0c;其他用户可以收到这个人的下线信息 服务器可以发送系统信息实现模型 模型&#xff1a; 代码&#xff1a; //chatser.c -- 服务器端实现 #include <stdio.h>…

hive初始化失败报错:Error: Duplicate key name ‘PCS_STATS_IDX‘ (state=42000,code=1061)

意思是key name ‘PCS_STATS_IDX’ (state42000,code1061)重复了&#xff0c;问题出在不是第一次初始化&#xff0c;因为我们在hive-site.xml中配置了 javax.jdo.option.ConnectionURL jdbc:mysql://192.168.200.137:3306/metastore?createDatabaseIfNotExisttrue JDBC conne…

JavaSE——类和对象(二)~~封装

目录 一.封装 二.封装扩展之包 三.static成员 四. 代码块 五. 内部类&#xff08;重要&#xff09; 大家好呀&#xff0c;我是北纬&#xff0c;接着上节我们继续讲解Java中关于类和对象的相关知识&#xff0c;今天着重给大家介绍一下关于面向对象程序的特性之一——封装。…

【Linux】常用基础命令 | 搭建云服务器优化环境 | 程序的部署

文章目录 Linux常用命令及搭建环境一、LinuxLinux发行版 1.常用命令1.ls2.cd3.pwd4.touch5.cat6.echo7.vim8.mkdir9.rm10.mv11.cp12.man13.grep14.ps15.netstat 2.搭建Java Web程序的运行环境包管理器1.安装JDK2.安装Tomcat3.安装mysql 3.程序的部署 Linux常用命令及搭建环境 …

贪心算法简单介绍

贪心算法是一种在每一步选择中都采取当前状态下最优或最优近似的选择&#xff0c;以期望最终得到全局最优解的算法。贪心算法并不总能得到全局最优解&#xff0c;但在某些问题上&#xff0c;它可以得到全局最优解&#xff0c;并且比动态规划等其他方法更为简单和高效。 贪心算…

Python库之Scrapy的简介、安装、使用方法详细攻略

Python库之Scrapy的简介、安装、使用方法详细攻略 简介 Scrapy是一个快速的、高层次的web抓取和web抓取框架&#xff0c;用于抓取网站数据并从页面中提取结构化的数据。Scrapy用途广泛&#xff0c;可以用于数据挖掘、信息处理或存储历史数据&#xff0c;以及各种其他用途。 …

【AMS】Android 8.0+ 绕开启动后台Service限制

一、背景 应客户要求,需要在开机时,拉起应用A。但因为开机时,同时被拉起的应用过多,导致Launcher在开机那一刻较为卡顿。为解决这一问题,采取了延迟拉起的做法。在开机后,延迟一定时间,由系统服务,拉起应用A。 于是乎,就出现这么个报错: Not allowed to start ser…

vue3、vuex和vue-router入门指南

Vue 3、Vuex 和 Vue Router 都是 Vue.js 生态系统中非常有用的库。它们各自在 Vue.js 应用程序中扮演着重要的角色&#xff1a;Vue 3 是核心框架&#xff0c;Vuex 用于状态管理&#xff0c;而 Vue Router 用于路由管理。下面是如何在 Vue 3 项目中使用这些库的简要说明。 创建…

有趣的css - 移形换位加载动画

大家好&#xff0c;我是 Just&#xff0c;这里是「设计师工作日常」&#xff0c;今天分享的是一个移形换位动态加载小动效&#xff0c;适用于 app 列表加载&#xff0c;页面加载或者图片懒加载等场景。 最新文章通过公众号「设计师工作日常」发布。 目录 整体效果核心代码html…

2024上海初中生古诗文大会倒计时4个月:单选题真题解析(持续)

现在距离2024年初中生古诗文大会还有4个多月时间&#xff0c;我们继续来看10道选择题真题和详细解析&#xff0c;以下题目截取自我独家制作的在线真题集&#xff0c;都是来自于历届真题&#xff0c;去重、合并后&#xff0c;每道题都有参考答案和解析。 为帮助孩子自测和练习&…

C#基础一

使用Visual Studio 2022&#xff08;VS2022&#xff09;编写C#控制台程序 1. 安装Visual Studio 2022 确保已安装Visual Studio 2022。如果未安装&#xff0c;请从Visual Studio官网下载并安装。 另一篇文章中已经有详细描述&#xff0c;这里就不在细说了。 VisualStudio2022…

【LeetCode】【209】长度最小的子数组(1488字)

文章目录 [toc]题目描述样例输入输出与解释样例1样例2样例3 提示进阶Python实现前缀和二分查找滑动窗口 个人主页&#xff1a;丷从心 系列专栏&#xff1a;LeetCode 刷题指南&#xff1a;LeetCode刷题指南 题目描述 给定一个含有n个正整数的数组和一个正整数target找出该数组…

Effective C++(2)

文章目录 2. 构造、析构、赋值运算条款05&#xff1a;了解C默默编写并调用哪些函数条款06&#xff1a;若不想使用编译器自动生成的函数&#xff0c;就该明确拒绝条款07&#xff1a;为多态基类声明virtual析构函数条款08&#xff1a;别让异常逃离析构函数条款09&#xff1a;绝不…

微信小程序报错:notifyBLECharacteristicValueChange:fail:nodescriptor的解决办法

文章目录 一、发现问题二、分析问题二、解决问题 一、发现问题 微信小程序报错&#xff1a;notifyBLECharacteristicValueChange:fail:nodescriptor 二、分析问题 这个提示有点问题&#xff0c;应该是该Characteristic的Descriptor有问题&#xff0c;而不能说nodescriptor。 …

web前端之解决img元素组件自有高度的问题

MENU 前言解决办法vertical-align 前言 在HTML和CSS中&#xff0c;img元素默认是行内元素(inline element)&#xff0c;类似于文本。由于文本有基线(baseline)&#xff0c;所以即使是空白的img元素也会占据一定的高度&#xff0c;以便使基线对齐。 解决办法 要解决这个问题&…

axios如何传递数组作为参数,后端又如何接收呢????

前端的参数是一个数组。 前端编写&#xff1a; 后端接收&#xff1a;

Iterater迭代器和增强for循环

1、Collection接口遍历元素—Iterator迭代器 看一下下面这张图片&#xff1a;可以看出Collection接口有一个父接口Iterable&#xff0c;Iterable接口有一个iterator()方法&#xff0c;iterator()方法的类型是Iterator迭代器&#xff0c;实际上当我们使用方法时&#xff0c;返回…