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);
}
}
Friendhosting发布了今年黑色星期五促销活动,针对全场VDS主机提供45折优惠码,虚拟主机4折,老用户续费可获9折加送1个月使用时长,优惠后VDS最低仅€14.53/年起,商家支持PayPal、信用卡、支付宝等付款方式。这是一家成立于2009年的老牌保加利亚主机商,提供的产品包括虚拟主机、VPS/VDS和独立服务器租用等,数据中心可选美国、保加利亚、乌克兰、荷兰、拉脱维亚、捷克、瑞士和波...
稳爱云(www.wenaiyun.com)是创建于2021年的国人IDC商家,主要目前要出售香港VPS、香港独立服务器、美国高防VPS、美国CERA VPS 等目前在售VPS线路有三网CN2、CN2 GIA,该公司旗下产品均采用KVM虚拟化架构。机房采用业内口碑最好香港沙田机房,稳定,好用,数据安全。线路采用三网(电信,联通,移动)回程电信cn2、cn2 gia优质网络,延迟低,速度快。自行封装的...
提速啦(www.tisula.com)是赣州王成璟网络科技有限公司旗下云服务器品牌,目前拥有在籍员工40人左右,社保在籍员工30人+,是正规的国内拥有IDC ICP ISP CDN 云牌照资质商家,2018-2021年连续4年获得CTG机房顶级金牌代理商荣誉 2021年赣州市于都县创业大赛三等奖,2020年于都电子商务示范企业,2021年于都县电子商务融合推广大使。资源优势介绍:Ceranetwo...
java移位为你推荐
贸易配额纺织品进出口配额是什么renderpartialrenderHtml和render有什么区别avc是什么格式电厂AVC啥意思?公众号付费阅读为什么微信公众号阅读要收费?无处不在的意思人山无处不花枝的意思是什么pat是什么格式pat是什么格式的文件啊shoujiao如何区分是不是颈椎病?averagesPoisson-Arrivals-See-Time-Averages是什么意思全局钩子加载全局钩子是什么,每次进入股票软件都说加载全局钩子,是中病毒了吗怎么查微信注册时间微信号用了多久,怎么知道
已备案域名注册 美国vps 科迈动态域名 512av 线路工具 12306抢票助手 免费网络电视 免费个人空间 免费吧 web服务器安全 如何安装服务器系统 卡巴斯基免费试用版 中国电信宽带测速器 江苏双线服务器 服务器维护 cdn网站加速 工信部icp备案查询 godaddy空间 江苏双线 免费获得q币 更多