【C++】华为研发工程师编程题

牛客网题目连接

1.汽水瓶

某商店规定:三个空汽水瓶可以换一瓶汽水,允许向老板借空汽水瓶(但是必须要归还)。
小张手上有n个空汽水瓶,她想知道自己最多可以喝到多少瓶汽水。
数据范围:输入的正整数满足 1≤n≤100

注意:本题存在多组输入。输入的 0 表示输入结束,并不用输出结果。

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

int main() {
    int a;
    vector<int> vec;
    while (cin >> a) { // 注意 while 处理多个 case
        if(a==0) break;
        vec.push_back(a);
    }
    //如果剩两个空瓶就可以借,剩一个空瓶直接输出
    for(int i=0;i<vec.size();i++){
        int sum=vec[i]/3;//可以喝到的汽水瓶数
        int res=vec[i]%3+vec[i]/3;//手上的空瓶数
        while(res!=1){
            sum+=res/3;
            res=res%3+res/3;
            
            if(res==2){//如果手上只有两个空瓶可以直接处理,避免产生死循环
                sum+=1;
                break;
            }
            
        }
        cout<<sum<<endl;
        
    }
}
// 64 位输出请用 printf("%lld")

2.明明的随机数

明明生成了N个1到500之间的随机整数。请你删去其中重复的数字,即相同的数字只保留一个,把其余相同的数去掉,然后再把这些数从小到大排序,按照排好的顺序输出。

数据范围: 1≤n≤1000 ,输入的数字大小满足 1≤val≤500

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

int main() {
    int n, b;
    cin>>n;
    set<int> num;
    while(n--){
        cin>>b;
        num.insert(b);
    }
    for(auto it=num.begin();it!=num.end();it++){
        cout<<*it<<endl;
    }
}
// 64 位输出请用 printf("%lld")

3.进制转换

写出一个程序,接受一个十六进制的数,输出该数值的十进制表示。

数据范围:保证结果在 1≤n≤2 ^31 −1

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

int main() {
    string str;
    cin>>str;//可以直接用cin输入字符串,读取到空格停止

    int k=str.size()-2;
    int index=1;
    int sum=0;
    for(int i=2;i<str.size();i++,index++){
        int l=1;//该位置对应的阶数
        for(int j=0;j<k-index;j++) l=l*16;
        int num=0;
		
		//将十六进制字符转成整数
        if(str[i]>='A'){
           num=str[i]-'A'; 
           num+=10;
        }
        else num=str[i]-'0';
        sum+=num*l;
    }
    cout<<sum<<endl;
}
// 64 位输出请用 printf("%lld")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值