import java.util.Arrays; public class Main { public static void main(String[] args) { // 当a和b最高位1的位置不同时有 // a^b > a&b int[] item = new int[]{4, 3, 5, 2}; int[] flag = new int[item.length]; for (int i = 0; i < item.length; i++) { flag[i] = 32 - Integer.numberOfLeadingZeros(item[i]); } Arrays.sort(flag); int[] dp = new int[item.length]; for (int i = flag.length - 2; i >= 0; i--) { if (flag[i] == flag[i + 1]) { dp[i] = dp[i + 1]; } else { dp[i] = flag.length - i - 1; } } System.out.println(Arrays.stream(dp).sum()); } } 给你提供一份参考代码,不知道能不能过
点赞 评论

相关推荐

12-24 14:26
东北大学 Java
一只乌鸦:重邮+东北,好经典的学校
最后再改一次简历
点赞 评论 收藏
分享
12-13 14:51
已编辑
井冈山大学 算法工程师
龙虾x:算法比你强的没有你美,比你美的…..算了已经没有比你美的了
工作两年想退休了
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务