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);
}
}
搬瓦工最近新增了荷兰机房中国联通(AS9929、AS4837)线路的VPS产品,选项为NL - China Unicom Amsterdam(ENUL_9),与日本软银和洛杉矶(DC06)CN2 GIA配置一致可以互换,属于高端系列,2.5Gbps-10Gbps大带宽,最低季付46.7美元起。搬瓦工VPS隶属于老牌IT7公司旗下,主要提供基于KVM架构VPS主机,数据中心包括美国洛杉矶、凤凰城、纽...
捷锐数据官网商家介绍捷锐数据怎么样?捷锐数据好不好?捷锐数据是成立于2018年一家国人IDC商家,早期其主营虚拟主机CDN,现在主要有香港云服、国内物理机、腾讯轻量云代理、阿里轻量云代理,自营香港为CN2+BGP线路,采用KVM虚拟化而且单IP提供10G流量清洗并且免费配备天机盾可达到屏蔽UDP以及无视CC效果。这次捷锐数据给大家带来的活动是香港云促销,总共放量40台点击进入捷锐数据官网优惠活动内...
企鹅小屋:垃圾服务商有跑路风险!企鹅不允许你二次工单的,二次提交工单直接关服务器,再严重就封号,意思是你提交工单要小心,别因为提交工单被干了账号!前段时间,就有站长说企鹅小屋要跑路了,站长不太相信,本站平台已经为企鹅小屋推荐了几千元的业绩,CPS返利达182.67CNY。然后,站长通过企鹅小屋后台申请提现,提现申请至今已经有20几天,企鹅小屋也没有转账。然后,搞笑的一幕出现了:平台账号登录不上提示...
java移位为你推荐
暴力破解rar对RAR压缩包进行解压时需要密码,使用暴力破解仍无法解码该怎么办?webservice框架java Webservice都有哪几种方式啊,哪种方式比较好啊webservice框架什么是webservice,什么情况下使用,如何使用微信如何只发文字微信朋友圈怎样只发文字怎样删除聊天记录怎么批量清除微信聊天记录driversbackup为什么电脑开机时一直进backup systemibooks支持什么格式iPhone4的ibooks怎么导入电子书 还有支持什么格式空间刷人气空间怎么刷人气?一天最高可以刷多少?cpu仪表盘cpu型号标示数字是什么意思yy语音注册歪歪语音如何安装与注册?
大硬盘 香港cdn 日志分析软件 godaddy域名证书 建立邮箱 网站在线扫描 网购分享 酸酸乳 测试网速命令 卡巴斯基官网下载 hostease 服务器防御 phpinfo cx域名 asp介绍 cpu使用率过高怎么办 cc加速器 留言板 免费网络电视直播 大容量存储控制器 更多