夯实基础——P2084 进制转换

题目链接:https://www.luogu.org/problem/P2084

P2084 进制转换

题目背景

题目描述

今天小明学会了进制转换,比如(10101)2 ,那么它的十进制表示的式子就是 :

1*2^4+0*2^3+1*2^2+0*2^1+1*2^0,

那么请你编程实现,将一个M进制的数N转换成十进制表示的式子。

注意:当系数为0时,该单项式要省略。

输入格式

两个数,M和N,中间用空格隔开。

输出格式

共一行,一个十进制表示的式子。

输入输出样例

输入 #1复制
2 10101
输出 #1复制
1*2^4+1*2^2+1*2^0

说明/提示

对于100%的数据,1<M<10,N的位数不超过1000。

这道基础题的考点是有关于N进制的转换问题。

关于进制转换,我相信学过计算机的人都应有所了解,但既然写博客的目的是记录学习过程,夯实基础,那在这里我还是详细的说一下吧!

以二进制转十进制为例:

例如:101011 ,其实就是基数为2的幂的和,也就是1*2^5 + 0*2^4 + 1*2^3 + 0*2^2 + 1*2^1 + 1*2^0

公式就是:abcd.efg(2)=d*20+c*21+b*22+a*23+e*2-1+f*2-2+g*2-3(10)

小数部分暂且说(其实就是把幂依次降低)


至于十进制转二进制的方法想必不用我多说了吧(相信你们都会

1 while(m!=0)
2 {
3     a[++k]=m%2;
4     m/=2;
5 }

 

*总的来说:

N进制转M进制的方法:

·1.可以先全化成二进制,在转换成M进制 (简单但复杂)

·2.直接转换(麻烦且容易出错的简便)

 

所以这道题你只要懂了进制之间的转换关系,其实很简单的。

 1 #include <cstring>
 2 #include <iostream>
 3 
 4 using namespace std;
 5 
 6 int n, len;
 7 
 8 string a;
 9 
10 int main()
11 {
12     cin >> n >> a;
13     len = a.size() - 1;
14     int k = 0;
15     for (int i = 0; i <= len; i++)
16         if (a[i] == '0')
17             k++;
18     k = len - k;
19     int tmp = len;
20     for (int i = 0; i <= len; i++)
21     {
22         if (a[i] == '0')
23         {
24             tmp--;
25             continue;
26         }
27         else
28         {
29             cout << a[i] << "*" << n << "^" << tmp;
30             if (k)
31             {
32                 cout << "+";
33                 k--;
34             }
35             tmp--;
36         }
37     }
38     return 0;
39 }

 

夯实基础,认真做好每一道题!!!

作者:Gmax

本文版权归作者和博客园共有,转载请用链接,请勿原文转载,Thanks♪(・ω・)ノ

2019-08-10

abcd.efg(2)=d*20+c*21+b*22+a*23+e*2-1+f*2-2+g*2-3(10)

转载于:https://www.cnblogs.com/Gmax/p/11332836.html

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

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

相关文章

网易资深Java架构师:java方法的定义和使用

前言 今年因为这个疫情&#xff0c;感觉这是从工作以来过的最久的一个年了&#xff0c;在家呆的时间不是一般的久&#xff0c;算一算有好几个月呢&#xff01;我大概是3月底快4月了才出门&#xff0c;投了超多的简历&#xff0c;天天面试面试面试面试面试面试面试…庆幸的是还…

PHP----学生管理系统

闲来无事花费两天时间写了份简易版的学生管理系统 源码地址:https://www.cnblogs.com/post/ReadAuth?blogId509327&PostId11333758&url%2Fbyczyz%2Fprotected%2Fp%2F11333758.html 转载于:https://www.cnblogs.com/byczyz/p/11333760.html

网易资深Java架构师:jdkjrejvm的区别和联系

前言 作为同时具备高性能、高可靠和高可扩展性的典型键值数据库&#xff0c;Redis不仅功能强大&#xff0c;而且稳定&#xff0c;理所当然地成为了大型互联网公司的首选。 众多大厂在招聘的时候&#xff0c;不仅会要求面试者能简单地使用Redis&#xff0c;还要能深入地理解底…

深度学习之开端备注

Adagrad //适合稀疏样本 RMSprop//借鉴Adagrad的思想&#xff0c;改进使得不会出现学习率越来越低的问题 由此可见Adadelta既不需要输入学习率等参数&#xff0c;而且表现得非常好&#xff01;&#xff01;但是我试了几次&#xff0c;这个优化器效果极差&#xff01;&#xff0…

网易资深Java架构师:疫情对java行业的影响分析

前言 在实际开发&#xff0c;Redis使用会频繁&#xff0c;那么在使用过程中我们该如何正确抉择数据类型呢&#xff1f;哪些场景下适用哪些数据类型。而且在面试中也很常会被面试官问到Redis数据结构方面的问题&#xff1a; Redis为什么快呢&#xff1f;为什么查询操作会变慢了…

ListView与.FindControl()方法的简单练习 #2 -- ItemUpdting事件中抓取「修改后」的值

原文出處 http://www.dotblogs.com.tw/mis2000lab/archive/2013/06/24/listview_itemupdating_findcontrol_20130624.aspx ListView与.FindControl()方法的简单练习 #2 -- ItemUpdting事件中抓取「修改后」的值 本文跟上一篇文章有关连&#xff0c;请依照顺序来练习&#xff1…

美团java研发岗二面:java静态方法存储在哪个区

思维导图 前言 在很多时候&#xff0c;我们都可以在各种框架应用中看到ZooKeeper的身影&#xff0c;比如Kafka中间件&#xff0c;Dubbo框架&#xff0c;Hadoop等等。为什么到处都看到ZooKeeper&#xff1f; 一、 前些年&#xff0c;互联网行业里对架构师这个岗位的标准还不是…

[学习之道] 修福不修慧,大象披璎珞; 修慧不修福,罗汉托空钵 (学习写程序,只靠补习上课吗?)...

这是我的备份&#xff0c;原文请看 http://www.dotblogs.com.tw/mis2000lab/archive/2014/09/17/learning-and_do-it_20140917.aspx [学习之道] 修福不修慧&#xff0c;大象披璎珞&#xff1b; 修慧不修福&#xff0c;罗汉托空钵 (学习写程序&#xff0c;只靠补习上课吗&#…

阿里P8亲自教你!mysql列转行

前言 今日博主听闻&#xff0c;现在很多培训出来的应届生薪资都赶上了摸爬滚打两三年的朋友&#xff0c;讲道理&#xff0c;这说不过去啊 作为同行来说&#xff0c;这个行业发展很快&#xff0c;技术更新很快&#xff0c;淘汰也很快&#xff0c;千万不要再找借口了&#xff0…

同步、异步、多线程

1、首先明确一点&#xff0c;对于单核CPU&#xff0c;任意一个时刻只有一个线程在运行。那么既然这样&#xff0c;多线程还有什么意义呢&#xff1f; 举例来说&#xff0c;现在只有一个人&#xff0c;要做好几个任务。单线程就是&#xff0c;任务一个一个地做&#xff0c;必须做…

阿里P8亲自教你!熬夜整理华为最新Java笔试题

前言 Mysql的锁机制确实非常重要&#xff0c;所以在这里做一个全面的总结整理&#xff0c;便于以后的查阅&#xff0c;也分享给大家。 Mysql的锁机制还是有点难理解的&#xff0c;所以这篇文章采用图文结合的方式讲解难点&#xff0c;帮助大家理解&#xff0c;讲解的主要内容…

JSP基础笔记

/** #####这部分也是笔记,用于记录JSP的相关内容* ###怎么用JSP###指令的写法* <% 指令名字%>* *### page指令 * language > 表明jsp页面中可以写java代码 * contentType > 其实即使说这个文件是什么类型&#xff0c;告诉浏览器我是什么内容类型&#xff0c;以及使…

阿里P8亲自讲解!javawhile循环语句用法

前言 作为一个已经毕业的计算机专业学长&#xff0c;其实几年大学走来还是挺感慨万千的。&#xff08;说明一下&#xff1a;一本&#xff0c;非958、211&#xff09; 老实说&#xff0c;上大学之前填志愿选专业的时候没有任何打算&#xff0c;就觉得学海熬到头了&#xff0c;向…

Cookie,Session基础知识

//这部分主要是CookieSession的笔记部分/** //获取来访的客户端类型String clientTyereq.getHeader("User-Agent");//如果是火狐浏览器&#xff0c;那么使用以下代码if(clientTye.contains("Firefox")){fileNameDownLoadUtil.base64EncodeFileName(fileNam…

阿里P8亲自讲解!java中级开发工程师需要掌握的技能

前言 关于技术人如何成长的问题&#xff0c;一直以来都备受关注&#xff0c;因为程序员职业发展很快&#xff0c;即使是相同起点的人&#xff0c;经过几年的工作或学习&#xff0c;会迅速拉开极大的差距&#xff0c;所以技术人保持学习&#xff0c;提升自己&#xff0c;才能够…

随笔--互联网进化论

不闻不若闻之&#xff1b;有的人士的理论引起了轰动&#xff0c;吾等小网民也来学学&#xff0c;没那么大脑袋&#xff0c;从不敢谈解读与批判。闻香而来&#xff0c;放屁而去。比如说互联网进化论。看看实践&#xff0c;互联网的膨胀式发展是不会停的&#xff0c;在中国的互联…

阿里P8亲自讲解!java分布式需要学什么技术

引言 最近项目上线的频率颇高&#xff0c;连着几天加班熬夜&#xff0c;身体有点吃不消精神也有些萎靡&#xff0c;无奈业务方催的紧&#xff0c;工期就在眼前只能硬着头皮上了。脑子浑浑噩噩的时候&#xff0c;写的就不能叫代码&#xff0c;可以直接叫做Bug。我就熬夜写了一个…

Javascript的this用法

出自&#xff1a;http://www.ruanyifeng.com/blog/2010/04/using_this_keyword_in_javascript.html this是Javascript语言的一个关键字。 它代表函数运行时&#xff0c;自动生成的一个内部对象&#xff0c;只能在函数内部使用。比如&#xff0c; function test(){ this.x 1; }…

[New Portal]Windows Azure Web Site (4) Web Site Gallery

《Windows Azure Platform 系列文章目录》 前言&#xff1a;最近因为工作变动&#xff0c;更新博客的速度变慢了。笔者在这边感到非常抱歉&#xff0c;以后尽量每周更新一篇Windows Azure的博客给大家。 好了&#xff0c;我们回到本章内容。 Windows Azure通过Web Role和Worker…

阿里P8亲自讲解!java声明类的语法格式

前言 前两天&#xff0c;我收到了蚂蚁金服的offer&#xff0c;从朋友的内推开始面试到拿到最后offer经历了4面技术、一面交叉面和一面HR面。经过了漫长的等待和几次几乎折磨的面试之后&#xff0c;终于拿到了offer。 分享第一份Java基础-中级-高级面试集合 Java基础&#xff…