java移位关于java的左移运算符的例子,谁能提供一下
java移位 时间:2021-06-17 阅读:(
)
java循环矩阵移位
import?java.util.Scanner;
public?class?FiveJuZheng?{
public?static?void?main(String[]?args)?{
int[][]?arr?=?{?{?1,?2,?3,?4,?5?},?{?6,?7,?8,?9,?10?},
{?11,?12,?13,?14,?15?},?{?16,?17,?18,?19,?20?},
{?21,?22,?23,?24,?25?}?};
int?x?=?0?,?y?=?0;
boolean?flag?=?true;
Scanner?sc?=?new?Scanner(System.in);
do?{
System.out.println("请输入两个位移量(注:不能超过5或者-5,用空格分开)");
String?readline?=?sc.nextLine();
String[]?numbers?=?readline.split("?");
if(numbers.length?2){
System.out.println("警告!输入有误:少于两个数!");
continue;
}
x?=?Integer.parseInt(numbers[0]);
y?=?Integer.parseInt(numbers[1]);
if(numbers.length?==?2?&&?x?5?&&?x?>?-5?&&?y?5?&&?y?>?-5){
flag?=?false;
}else{
System.out.println("警告!输入有误:数值须在(-5?,5)内,不包括-5和5!");
}
}?while?(flag);
arr?=?xidc(arr,?x);
arr?=?yidc(arr,?y);
for?(int?i?=?0;?i?5;?i++)?{
for?(int?j?=?0;?j?5;?j++)?{
System.out.print(arr[i][j]?+?" ");
}
System.out.println();
}
}
/**
?*?处理数组下沉
?*?@param?arr?源数组
?*?@param?x?下沉行数
?*?@return?下沉后的数组
?*/
private?static?int[][]?xidc(int[][]?arr,?int?x)?{
int[]?temp?=?new?int[5];
if?(x?0)?{
x?=?5?+?x;?//输入为负时换成对应的正数行??上浮2行?等于?下沉3行
}
for?(int?k?=?0;?k??0;?i--)?{
int?line?=?i?-?1;
temp?=?arr[i];
arr[i]?=?arr[line];
arr[line]?=?temp;
}
}
return?arr;
}
/**
?*?处理数组向右移动
?*?@param?arr?源数组
?*?@param?y?右移列数
?*?@return?移位后数组
?*/
private?static?int[][]?yidc(int[][]?arr,?int?y)?{
int[]?temp?=?new?int[5];
if?(y?0)?{
y?=?5?+?y;??//输入为负时换成对应的正数行??左移2列?等于?右移3列
}
for?(int?k?=?0;?k??0;?i--)?{
int?line?=?i?-?1;
for?(int?j?=?0;?j?5;?j++)?{
temp[j]?=?arr[j][i];
arr[j][i]?=?arr[j][line];
arr[j][line]?=?temp[j];
}
}
}
return?arr;
}
}简测可以达到效果。
java位移运算
java中整数int的位数是32位,如果是要这个数的32位从左算起的第4位到第7位为0,则只需要将该数按位与上0xE1FFFFFF,即110&0xE1FFFFFF。
不过这样与了之后,110的值不变,因为110的二进制表示是32位表示的,所以从左算起的第4个到第七个位都是0。
如果是从右开始的第4位到第7位就是按位与上0xFFFFFF87,即110&0xFFFFFF87.java数组整体移位问题?如将{1,3,1,2,3,2,3,2}移成{1,1,2,2,2,3,3,3} 如何高效实现。
就是把里面所有的3移动到最后,其他的顺序前移?没法可选的时候我会用遍历,循环来做。
public class ClassB {
public static void main(String... arg){
int [] a = {1,3,2,4,65,21,3,546,3,2,1};
for(int i=0;i<a.length;i++){
if(a[i]==3){
int n =i;
for(int j=n+1;j<a.length;j++){
a[n]=a[j];
n++;
}
a[a.length-1]=3;
}
}
for(int i =0;i<a.length;i++){
System.out.print(a[i]+" ");
}
}
}
方法笨一点,用还是可以用的
1 2 4 65 21 546 2 1 3 3 3Java 移位>>运算符,看代码。
-4的二进制表示为1111 1111 1111 1011
i>>3 右移3位,移出的不管,左端补1 变为1111 1111 1111 1111 这是-1的二进制表示,所以结果为-1.
i>>5 同理。
具体原理:
先来说一下怎么得出负数的二进制。
原码,反码,补码,这三个概念搞清。
1、原码:一个正数,按照绝对值大小转换成的二进制数;一个负数按照绝对值大小转换成的二进制数,然后最高位补1,称为原码。
比如 00000000 00000000 00000000 00000101 是 5的 原码。
10000000 00000000 00000000 00000101 是 -5的 原码。
备注:
比如byte类型,用2^8来表示无符号整数的话,是0 - 255了;如果有符号, 最高位表示符号,0为正,1为负,那么,正常的理解就是 -127 至 +127 了.这就是原码了,值得一提的是,原码的弱点,有2个0,即+0和-0(10000000和00000000);还有就是,进行异号相加或同号相减时,比较笨蛋,先要判断2个数的绝对值大小,然后进行加减操作,最后运算结果的符号还要与大的符号相同;于是,反码产生了。
2、反码:正数的反码与原码相同,负数的反码为对该数的原码除符号位外各位取反[每一位取反(除符号位)]。
取反操作指:原为1,得0;原为0,得1。
(1变0; 0变1)
比如:正数00000000 00000000 00000000 00000101 的反码还是 00000000 00000000 00000000 00000101
负数10000000 00000000 00000000 00000101 的反码则是 11111111 11111111 11111111 11111010。
反码是相互的,所以也可称:10000000 00000000 00000000 00000101 和 11111111 11111111 11111111 11111010互为反码。
备注:还是有+0和-0,没过多久,反码就成为了过滤产物,也就是,后来补码出现了。
3、补码:正数的补码与原码相同,负数的补码为对该数的原码除符号位外各位取反,然后在最后一位加1.
比如:10000000 00000000 00000000 00000101 的补码是:11111111 11111111 11111111 11111010。
那么,补码为:
11111111 11111111 11111111 11111010 + 1 = 11111111 11111111 11111111 11111011
备注:1、从补码求原码的方法跟原码求补码是一样的 ,也可以通过完全逆运算来做,先减一,再取反。
2、补码却规定0没有正负之分
所以,-5 在计算机中表达为:11111111 11111111 11111111 11111011。
转换为十六进制:0xFFFFFFFB。
搞懂二进制表示后,再来说一下左移右移运算符。
左移运算是将一个二进制位的操作数按指定移动的位数向左移位,移出位被丢弃,右边的空位一律补0。
右移运算是将一个二进制位的操作数按指定移动的位数向右移动,移出位被丢弃,左边移出的空位或者一律补0,或者补符号位,这由不同的机器而定。
在使用补码作为机器数的机器中,正数的符号位为0,负数的符号位为1。
(均由机器来定)
So,为什么得到-1知道了吧~~~关于java的左移运算符的例子,谁能提供一下
value << num
num 指定要移位值value 移动的位数
class ByteShift {
public static void main(String args[]) {
byte a = 64, b;
int i;
i = a << 2;
b = (byte) (a << 2);
System.out.println("Original value of a: " + a);
System.out.println("i and b: " + i + " " + b);
}
}
这几天有几个网友询问到是否有Windows VPS主机便宜的VPS主机商。原本他们是在Linode、Vultr主机商挂载DD安装Windows系统的,有的商家支持自定义WIN镜像,但是这些操作起来特别效率低下,每次安装一个Windows系统需要一两个小时,所以如果能找到比较合适的自带Windows系统的服务器那最好不过。这不看到PacificRack商家有提供夏季促销活动,其中包括年付便宜套餐的P...
DiyVM 香港沙田机房,也是采用的CN2优化线路,目前也有入手且在使用中,我个人感觉如果中文业务需要用到的话虽然日本机房也是CN2,但是线路的稳定性不如香港机房,所以我们在这篇文章中亲测看看香港机房,然后对比之前看到的日本机房。香港机房的配置信息。CPU内存 硬盘带宽IP价格购买地址2核2G50G2M1¥50/月选择方案4核4G60G3M1¥100/月选择方案4核8G70G3M4¥200/月选择...
819云互联 在本月发布了一个购买香港,日本独立服务器的活动,相对之前的首月活动性价比更高,最多只能享受1个月的活动 续费价格恢复原价 是有些颇高 这次819云互联与机房是合作伙伴 本次拿到机房 活动7天内购买独立服务器后期的长期续费价格 加大力度 确实来说这次的就可以买年付或者更长时间了…本次是5个机房可供选择,独立服务器最低默认是50M带宽,不限制流量,。官网:https://ww...
java移位为你推荐
贸易配额进出口配额是怎么回事情?英文名网站介绍几个好的英语学习网站windowsmedia为什么打开所有程序都出现Windows Media PlayerscriptmanagerScriptManager是什么素数算法求100以内的素数的算法excel大写金额在EXCEL表格里怎样自动生成金额大写刷ip流量免费刷流量软件有哪些?哪个免费刷流量工具最好?5e5e5e计算器里5.55556e-5是什么意思java程序员招聘女java程序员好找工作嘛sms是什么短信验证是什么?
国外空间租用 php主机租用 看国外视频直播vps 网易域名邮箱 plesk 5折 赵容 美国php主机 天猫双十一秒杀 ev证书 标准机柜尺寸 500m空间 e蜗牛 智能骨干网 微信收钱 帽子云 网站cdn加速 空间合租 ebay注册 徐州电信 更多