问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

JAVA 实现算法

发布网友 发布时间:2022-04-22 23:07

我来回答

5个回答

热心网友 时间:2023-09-26 17:16

稍微写了下,供你参考,见笑了。

public int getIntegerComplement(int N){
  int inversion=0;
  String binaryString=Integer.toBinaryString(N);
  char[] charArray=binaryString.toCharArray();
  StringBuffer sb=new StringBuffer();
  for(int i=0;i<charArray.length;i++){
   switch (charArray[i]) {
   case '0':
    sb.append("1");
    break;
   case '1':
    sb.append("0");
    break;
   default:
    System.out.println("error happens");
    break;
   }
  }
  String stringAfterInversion=sb.toString();
  System.out.println("stringAfterInversion:"+stringAfterInversion);
  inversion=Integer.parseInt(stringAfterInversion, 2);
  System.out.println("inversion value is:"+inversion);
  return inversion;
  
 }

热心网友 时间:2023-09-26 17:16

Integer.toBinaryString(i);

将十进制的数转化为二进制 得到一个string类型

然后在遍历这个数组 将0变成1 1变成0即可

Integer.parseInt(str, 10)可以把二进制转化为十进制

热心网友 时间:2023-09-26 17:17

编码是不能用字符串的,大大大降低速度

public class Test{
static public int getIntegerComplement(int n){
return ~n&((1<<(32-Integer.numberOfLeadingZeros(n)))-1);
}
public static void main(String[] args){
int a[]={1,5,50,256,65536};
for(int i:a){
int r=getIntegerComplement(i);
System.out.println(i+" "+Integer.toBinaryString(i)+
" => "+r+" "+Integer.toBinaryString(r));
}
}
}
========
1 1 => 0 0
5 101 => 2 10
50 110010 => 13 1101
256 100000000 => 255 11111111
65536 10000000000000000 => 65535 1111111111111111

热心网友 时间:2023-09-26 17:18

public class Convert {
public static void main(String[] args) {
for (int N = 0; N <= 10; N++) {
int value = getIntegerComplement(N);
System.out.print(N + "(" + toBinaryString(N) + ") -> ");
System.out.println(value + "(" + toBinaryString(value) + ")");
}
}
public static int getIntegerComplement(int n) {
int len = toBinaryString(n).length();
return Integer.parseInt(toBinaryString(~n).substring(32 - len), 2);
}
public static String toBinaryString(int n) {
return Integer.toBinaryString(n);
}
}

热心网友 时间:2023-09-26 17:18

推推,有人答了
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
吃生大蒜好吗 吃生大蒜有什么好处呢 保字词语接龙两个字 建筑设计资质有哪些 iphone视频格式 男人说纠结是什么意思纠结是什么意思 古天乐的资料!!! 胆结石可以喝柠檬蜂蜜水吗 柠檬对结石有什么作用 胆结石可以吃柠檬吗 江西有哪些风景 什么是工程总承包企业 成都景点排名 java中哪些可以涉及算法 “工程总承包”与“工程总承包”有什么区别? java 初级、中级、高级工程师有什么区别? 工程总承包的方式有哪些 《安全生产事故报告调查条例》中报告主体如何界定,工程总承包安全事故是建设方、总包方、分包方那个报? 成都景区排名是怎样的? 研究报告公司与调查报告公司有哪些,实力怎样? EPC工程总承包项目管理模式的现状分析和对策研究 java 初级、中级、高级工程师等 如何区分? 求成都景点排名,有哪些值得去? java如何计算比较复杂的数学计算,比如有括号同时有+-*&#47;,顺序不一定,就是一个运算公式 成都十大旅游景点排行榜,你想去哪个 java算法面试题:排序都有哪几种方法 小白该如何学习java算法? java程序员需要非常精通算法吗? java大数据颇有难度算法 JAVA算法 java中的算法,一共有多少种,哪几种,怎么分类。 EPC总承包项目全过程风险管理分析 工程总承包与施工总承包有什么区别? 谁能给出建筑业-土木工程建筑业行业分析报告,做资料要参考一下 设计-施工总承包与工程总承包的区别? 怎么才能把10分钟的长视频发送给微信好友?急!!! 工程总承包和施工总承包区别,通俗一点,定义不太明白。谢谢 工程总承包和工程项目管理业务有什么区别?为什么不能同时承担?还有为什么不能同时承担勘察、设计业务? 什么是建筑工程的总承包 工程项目管理和工程总承包的区别? 建设工程项目总承包和施工总承包的区别 “EPC”和“工程总承包”的区别是什么? 张家界莓茶哪里正宗? 湘西莓茶的功效与作用是什么? 张家界莓茶的功效与作用分别是什么? 这是什么茶? 张家界土家莓茶有哪些作用? 张家界土特产有哪些 张家界莓茶的功效与作用分别是? 莓茶是什么? 椰子鞋带系法是什么?