【算法3】将数组中的数拼成一个最大的数

比如:

输入 321 32 6

输出 632321

  #include<c++/4.8.2/iostream>
  #include<c++/4.8.2/vector>
  #include<c++/4.8.2/string>
  #include<c++/4.8.2/algorithm>
  
  using namespace std;
  bool com(string a,string b)//自定义比较函数
  {
      string str1=a+b;
      string str2=b+a;
      return str1>str2?true:false;
  }
  void largestNum(vector<int> a)
  {
      if(a.empty())
          return;
  
  //最后可能输出的数字过大,所以用字符串的方式处理
      vector<string> str;
      for(int i=0;i<a.size();i++)//先将数组元素转成string类型
      {   
          str.push_back(to_string(a[i]));
      }   
      sort(str.begin(),str.end(),com);//通过自定义比较函数,排序成从大到小
      for(int i=0;i<str.size();i++)
      {   
          cout<<str[i];
      }   
      cout<<endl;
  }
  int main()
  {
      vector<int> a;
      int n;
      while(cin>>n)
      {   
          a.push_back(n);
      }   
      largestNum(a);
  
     return 0;
  }

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当我们需要将一个 byte 数组转换为二进制字符串时,可以使用 Java 内置的 Integer 类的 toBinaryString() 方法。具体步骤如下: 1. 首先,将 byte 数组转换为 int 型数组,以便使用 toBinaryString() 方法。 2. 然后,遍历 int 数组,对每个元素使用 toBinaryString() 方法生成二进制字符串,并将它们拼接成一个完整的二进制字符串。 下面是一个示例代码: ```java public static String byteArrayToBinaryString(byte[] bytes) { int[] ints = new int[bytes.length]; for (int i = 0; i < bytes.length; i++) { ints[i] = bytes[i] & 0xFF; } StringBuilder sb = new StringBuilder(); for (int i = 0; i < ints.length; i++) { sb.append(String.format("%8s", Integer.toBinaryString(ints[i])).replace(' ', '0')); } return sb.toString(); } ``` 在这个方法中,我们首先将 byte 数组转换为 int 数组,以便于使用 toBinaryString() 方法。通过对每个 byte 数组元素进行 & 0xFF 操作,可以将 byte 类型的数据转换为 int 类型。然后,我们使用 StringBuilder 来拼接每个 int 数组元素的二进制字符串,并使用 format() 方法和 replace() 方法来格式化并补齐每个二进制字符串的位。 调用该方法,可以将一个 byte 数组转换为一个二进制字符串: ```java byte[] bytes = {0x12, 0x34, (byte) 0xAB, (byte) 0xCD}; String binaryString = byteArrayToBinaryString(bytes); System.out.println(binaryString); // 00010010001101000101001111001101 ``` 希望这个算法对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值