2024华为OD机试真题-找数字-(C++/Java/Python)-C卷D卷-200分

本文介绍了华为在线开发者(OD)机试C卷和D卷的一道真题,要求找到一个大于输入正整数n的最小数字m,使m和n在二进制表示下1的个数相同。题目给出了输入输出描述、用例以及Java解题代码,主要考察逻辑分析能力。
摘要由CSDN通过智能技术生成

【华为OD机试】-(A卷+B卷+C卷+D卷)-2024真题合集目录

【华为OD机试】-(C卷+D卷)-2024最新真题目录

题目描述

小扇和小船今天又玩起来了数字游戏,

小船给小扇一个正整数 n(1 ≤ n ≤ 1e9),小扇需要找到一个比 n 大的数字 m,使得 m 和 n 对应的二进制中 1 的个数要相同,如:

  • 4对应二进制100
  • 8对应二进制1000
  • 其中1的个数都为1个

现在求 m 的最小值。

输入描述

输入一个正整数 n(1 ≤ n ≤ 1e9)

输出描述

输出一个正整数 m

用例1

输入

2

输出

4

说明

2的二进制10,

4的二进制位100,

1的个数相同,且4是满足条件的最小数

用例2

输入

7

输出

11

说明

7的二进制111,

11的二进制位1011,

1的个数相同,且11是满足条件的最小数

用例3

输入

6

输出

9

说明

6的二进制0110,

9的二进制位1001,

1的个数相同,且11是满足条件的最小数

解题思路

本题可以通过把十进制数转化成二进制,然后移动1的位置来得到1个数不变,但更小的数。比如:

1000001

1000010

11101

11110

即只需要把最右边开始查到的第一对01变为10即可。

如果没有01的情况如何处理,比如1000,1111,只需要前面加个0,依然可以用前面的方法解答,

01000

10000

01111

10111

但还有一些特殊情况,上述方法不能解决,比如1001111000

1001111000

1010111000  //按照上述方法的答案

1010000111  //实际的正确答案

即01右边存在1时,需要把1全移到最右边。

考点

逻辑分析

代码

c++
#include <bits/stdc++.h>
using namespace std;

int main() {
    int n,ans=0;
    cin>>n;
    string str;
    while(n>0) {
        int res=n%2;
        str=to_string(res)+str;
        n=n/2;
    }
    str="0"+str; //十进制转成二进制字符串
    int onecnt=0; // 记录01右边1的个数
    int len=str.size();
    // 从最右边开始查找
    for(int i=len-2;i>=0;i--) {
        if(str[i]=='0' && str[i+1]=='1') {
            str[i]='1';
            str[i+1]='0';
            if(onecnt>0) {
                // 如果01右边存在1时,需要把1全移到最右边
                for(int j=i+2;j<len;j++) {
                    if(j<len-onecnt) {
                        str[j]='0';
                    }else{
                        str[j]='1';
                    }
                }
            }
            break;
        }
        //记录01右边1的个数
        if(str[i+1]=='1'){
            onecnt++;
        }
    }
    // 二进制字符串转换成10进制整数
    for(int i=0;i<str.size();i++) {
        ans=ans*2 + str[i]-'0';
    }
    cout<<ans<<endl;
    system("pause");
    return 0;
}
java
import java.util.Scanner;
 
public class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
 
    int n = sc.nextInt();
 
    String nBinStr = "0" + Integer.toBinaryString(n); //十进制转成二进制字符串
 
    char[] mBinCharArr = nBinStr.toCharArray();
 
    int countOne = 0; // 记录01右边1的个数
    // 从最右边开始查找
    for (int i = mBinCharArr.length - 2; i >= 0; i--) {
      if (mBinCharArr[i] == '0' && mBinCharArr[i + 1] == '1') {
        mBinCharArr[i] = '1';
        mBinCharArr[i + 1] = '0';
        //  如果01右边存在1时,需要把1全移到最右边
        if (countOne > 0) {
          for (int j = i + 2; j < mBinCharArr.length; j++) {
            if (j < mBinCharArr.length - countOne) {
              mBinCharArr[j] = '0';
            } else {
              mBinCharArr[j] = '1';
            }
          }
        }
 
        break;
      }
      //记录01右边1的个数
      if (mBinCharArr[i + 1] == '1') countOne++;
    }
    // 二进制字符串转换成10进制整数
    int m = Integer.parseInt(new String(mBinCharArr), 2);
    System.out.println(m);
  }
}
python
nb=bin(int(input())) #转为二进制字符串
nb="0"+nb[2:] #去掉0b前缀,并头部加0
arr=list(nb)
n=len(nb)
onecnt=0 #记录01右边1的个数
#从最右边开始查找
for i in range(n-2,-1,-1):
    if arr[i]=='0' and arr[i+1]=='1':
        arr[i]='1'
        arr[i+1]='0'
        if onecnt>0:
            # 如果01右边存在1时,需要把1全移到最右边
            for j in range(i+2,n):
                if j < n-onecnt:
                    arr[j]='0'
                else:
                    arr[j]='1'
        break
    # 记录01右边1的个数
    if arr[i+1]=='1':
        onecnt+=1
#二进制字符串转换成10进制整数
res=int(''.join(arr),2)
print(res)

目录

题目描述

输入描述

输出描述

用例1

用例2

用例3

解题思路

考点

代码

c++

java

python



首先,在选择服务中心的最佳位置时,我们需要考虑各种因素,包括人口密度、交通便利性、基础设施和竞争对手等。对于华为OD项目来说,我会推荐选址在人口密度相对较高的城市中心地带。这样可以确保服务中心能够覆盖到更多的用户群体,提高服务的便利性和覆盖面。 其次,交通便利性也是选择最佳位置的重要考量因素。一个位于交通枢纽地带的服务中心可以更容易地接触到周围城市的用户,减少用户的前往成本和时间。同时,也方便快速调度和配送产品,提高服务的效率和时效性。 此外,基础设施的完善也是一个重要的考虑因素。一个服务中心应该有稳定的电力、通讯和网络设施,以保证服务的持续性和稳定性。另外,周边商业设施和生活设施的配套也能吸引更多的顾客和员工,提高服务中心的吸引力和竞争力。 最后,对竞争对手的考虑也至关重要。在选择服务中心的位置时,需要做好竞争对手的地域析,避免选择在竞争对手的聚集地带,同时也要考虑如何在竞争对手密集的区域提供更优质的服务和更吸引人的特色,以获得竞争优势。 综上所述,选择服务中心最佳位置需要全面考虑各种因素,包括人口密度、交通便利性、基础设施和竞争对手,这样才能确保服务中心能够更好地为用户提供服务,同时也能提高企业的竞争力和影响力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2024剑指offer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值