linux系统计算器工具,Linux工具之bc计算器进制的转换

bc是Linux下的命令行式的计算器。 题目虽然叫任意进制,但是因为bc的限制,输入进制是216范围;输出进制是2999范围。这与常见计算器的进制范围是一致的,比如windows计算器最高也只能处理16进制输入数据。

一、bc计算器的使用

bc计算器默认输入、输出都为10进制。

[root@centos6 ~]# bc #打开bc计算器

bc 1.06.95

Copyright 2006 Free Software Foundation, Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

88*123 #计算 88*123

10824 #计算器输出结果

#

#

123+65*2-100 #计算123+65*2-100

153 #计算器输出结果

bc计算器进制转换

[root@centos6 ~]# bc

obase=16 #设置输出为16进制

ibase=2 #设置输入为2进制

1111111111111100011010 #输入2进制数

3FFF1A #转换为16进制

二、通过管道运算与进制转换

这里使用的管道可以简单的理解为将echo "1+2"发送给 bc计算器

[root@centos6 ~]# echo "1+1" | bc #将1+1发送给bc计算器

2

[root@centos6 ~]#

[root@centos6 ~]# echo "5*10-1" | bc #将5*10-1发送给bc计算器

49

双引号、单引号、反单引号的使用

[root@centos6 ~]# echo "123+123" | bc

246

[root@centos6 ~]# echo '111+111'

111+111

[root@centos6 ~]# echo '111+111' | bc

222

[root@centos6 ~]# echo `111+111` | bc

-bash: 111+111: command not found

[root@centos6 ~]# echo "`echo 123`+10" | bc

133

三、使用中遇到的问题

先设置obase在设置ibase,计算器正常。

[root@centos6 ~]# bc

bc 1.06.95

Copyright 2006 Free Software Foundation,

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

obase=16

ibase=2

1111111111111100011010

3FFF1A

先设置ibase在设置obase,计算器输出不正常。

[root@centos6 ~]# bc

bc 1.06.95

Copyright 2006 Free Software Foundation, Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

ibase=2

obase=16

1111111111111100011010

21220002012002

先设置obase在设置ibase,计算输出正常

修改obase后计算输出不正常

[root@centos6 ~]# bc

bc 1.06.95

Copyright 2006 Free Software Foundation, Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

obase=16

ibase=2

1111111111111100011010

3FFF1A

obase=10

1111111111111100011010

1111111111111100011010

先设置obase在设置ibase正常,ibase与obase互换输出不正常。

[root@centos6 ~]# bc

bc 1.06.95

Copyright 2006 Free Software Foundation, Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

obase=16

ibase=2

1111111111111100011010

3FFF1A

obase=2

ibase=16

3FFF1A

1011010101

使用管道时同样只能先给obase赋值

[root@centos6 ~]# echo "ibase=2;obase=16;11101" | bc

1002

[root@centos6 ~]# echo "obase=16;ibase=2;11101" | bc

1D

结论?????

在bc计算器中,obase与ibase的赋值有先后顺序。

且在计算过程中ibase与obase只能赋值一次。

ColorUtil【Color工具类(color整型、rgb数组、16进制互相转换)】

版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 主要用于color整型.rgb数组.16进制互相转换(-12590395 #3FE2C5 ...

字节流、字符串、16进制字符串转换__Java(转)

/** * @Package: * @ClassName:TypeConversion * @Description:字节流.字符串.16进制字符串转换 * @author:xk * @date:Ja ...

iOS 16进制字符串转换成int十进制

NSRange rangeErr; rangeErr.location = 6; rangeErr.length = 2; NSString *strings = [value substringWi ...

Java中将16进制字符串转换成汉字

技术交流群:233513714 /** * 将16进制字符串转换成汉字 * @param str * @return */ public static String deUnicode(String ...

N进制数组转换成正整数

给定一个任意长度的数组,其中的元素按照一定的进制(N进制)来转换成正整数 //把数组中的元素按照N进制转换成为正整数 #include #include

javascript 10进制和64进制的转换

原文:javascript 10进制和64进制的转换 function string10to64(number) { var chars = '0123456789abcdefghigklmnopqr ...

编程实现将一个N进制数转换成M进制数

问题:编程实现将一个N进制数转换成M进制数.(c/c++.Java.Javascript.C#.Python) 1.Python 手写算法版 def conversion_num(num, src, ...

java 的任意进制间转换

直接上代码: public class Main { public static void main(String[] args) { // TODO Auto-generated method st ...

C++实现16进制字符串转换成int整形值

开发中经常需要把16进制字符串转换成整形,写了个个代码供大家参考下: #include #include //字符转换成整形 int ...

随机推荐

ISO9126软件质量模型

ISO9126软件质量模型,是评价软件质量的国际标准.6个特性27个子特性组成. ISO/IEC9126软件质量模型是一种评价软件质量的通用模型,包括3个层次: 1.质量特性 2.质量子特性 3.度量 ...

poj1274 The Perfect Stall (二分最大匹配)

Description Farmer John completed his new barn just last week, complete with all the latest milking ...

Java 操作 Redis 高级

/Users/sherry/WorkPath/Git/Web/redisDemo/src/main/java/org/zln/utils/JedisUtils.java package org.zln ...

利用opencv3中的kmeans实现抠图功能

kmeans算法主要用来实现自动聚类,是一种非监督的机器学习算法,使用非常广泛.在opencv3.0中提供了这样一个函数,直接调用就能实现自动聚类,非常方便. 函数原型: C++: double km ...

[转贴]WebService的简单实现 C++

WebService的简单实现 一.socket主机创建和使用过程 1.socket()//创建套接字 2.Setsockopt()//将套接字属性设置为允许和特定地点绑定 3.Bind()//将套接 ...

有向图的欧拉路径POJ2337

每个单词可以看做一条边,每个字母就是顶点. 有向图欧拉回路的判定,首先判断入度和出度,其实这个题判定的是欧拉通路,不一定非得构成环,所以可以有一个点的顶点入度比出度大1,另外一个点的出度比入度大1,或 ...

WCF消息

1. MessageContract 序列化一个对象并生成消息的时候,希望将部分数据成员作为SOAP的报头,部分作为消息的主体.比如说,我们有一个服务操作采用流的方式进行文件的上载,除了以流的方式传输 ...

bzoj1188

题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1188 一道非常好的SG函数题,加深了对博弈论的理解. 以前做的SG函数的题,都是每个瓶子看成一 ...

Oracle 实现 mysql 的 find_in_set 排序!

oracle 实现类似MYSQL的 find_in_set 排序,函数 decode: select * from tb_info_game where gameid in(23,20,19,26,1 ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值