一点资讯0921编程题参考解题报告

奇怪的电梯

分析

做个bfs,然后记录路径即可,注意打印格式

参考代码

#include <iostream>
#include <algorithm>
#include <queue>

using namespace std;

const int maxn = 200 + 5;
int a[maxn], n;
bool flag[maxn];
int p, q;

struct node {
    int x;
    int t; 
} re[maxn];
int pr[205];

int BFS(int st, int et) {
    queue<node> Que;
    fill(flag, flag + maxn, 0);
    node temp;
    temp.x = st, temp.t = 0;
    Que.push(temp); 
    flag[st] = 1; 
    while (!Que.empty()) {
        node ppp = Que.front();
        Que.pop();
        if (ppp.x == et)return ppp.t;
        int x = ppp.x;
        if (x - a[x] >= 1 && !flag[x - a[x]]) {
            flag[x - a[x]] = 1;
            temp.x = x - a[x];
            temp.t = ppp.t + 1;
            pr[temp.x] = x;
            Que.push(temp);
        }
        if (x + a[x] <= n && !flag[x + a[x]]) {
            flag[x + a[x]] = 1;
            temp.x = x + a[x];
            temp.t = ppp.t + 1;
            pr[temp.x] = x;
            Que.push(temp);
        }
    }
    return -1;
}
void pri(int sx) {
    if( sx < 1) {
        return ;
    }
    pri(pr[sx]);
    if(sx == q)
        printf("%d\n", sx);
    else
        printf("%d ", sx);
}
int main() {
    scanf("%d%d%d", &n, &p, &q);
    for (int i = 1; i <= n; i++)
        scanf("%d", &a[i]);
    int ans = BFS(p, q);
    printf("%d\n", ans);
    if(ans != -1) pri(q);
    return 0;
}

二进制1的个数

分析

直接统计每个数也行。这里使用了GCC的一个内置函数__builtin_popcount() 功能就是统计二进制1的个数,注意一下打印格式就好了。

参考代码

#include <iostream>

using namespace std;

int main(){
    int n;
    scanf("%d",&n);
    if(n == 0){
        printf("[0]\n");
        return 0;
    }
    printf("[0,");
    for(int i = 1; i <= n; i++){
        if(i == n) printf("%d]",__builtin_popcount(i));
        else printf("%d,",__builtin_popcount(i));
    }
    printf("\n");
}
全部评论
二进制1的个数 #include<iostream> using namespace std; int main(){   int n; cin>>n; vector<int> res(n+1,0); for(int i = 1; i < res.size();i++) res[i] = i%2 + res[i/2]; cout<<"["; for(int i=0;i<n;i++){ cout<<i<<","; } cout<<res[n]<<"]"<<endl; return res; }
点赞 回复 分享
发布于 2016-09-22 08:45

相关推荐

04-13 18:10
门头沟学院 Java
想熬夜的小飞象在秋招:被腾讯挂了后爸妈以为我失联了
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
05-29 22:21
Offer1:小马智行,深圳,测试开发工程师,17.0k*16.0,Offer2:追觅科技,深圳,嵌入式工程师,18.0k*15.0,
嵌软狗都不学:各位base深圳的同事,作为也是并肩作战的一员,今天想站在管理视角,和大家开诚布公地聊一聊:从近几个月的上下班数据对比看来,我们发现一个明显的差异:深圳同事的在岗时间普遍比苏州同事短。很多深圳同事早上9点之后才到公司,晚上不到 20 点就下班了;而总部那边,20点半甚至 22 点后还有不少同事在办公室忙碌,特别是研发团队,加班更是常态。相信去过苏州的同事,对这种场景都不陌生。我很好奇,这是因为苏州工作任务太重还是咱们深圳同事效率真的高到能在更短时间内完成工作?MOVA在深圳成立分公司是为了吸引更优秀的人才贡献更多更高质的价值,公司管理层给我反馈的是深圳招到的多是行业的专家大拿,大部分都是薪资比苏州高的,而且我们办公的租金等也远高于苏州的..MOVA虽脱胎于强壮的集团母体不久,各业务板块尚未实现全面盈利,虽说公司管理层目光长远,不纠结当下的人才投入,但行业内的普遍标准是,员工创造的价值要达到公司雇佣成本的 15 倍以上。大家不妨自我审视一下,自己是否达到了这个标准?如果是抱着划水、按时打卡走人拿毛爷爷的心态那不适合来MOVA,那样过下去不但自己过得尴尬也会影响MOVA这个大船的攻城略地的速度.我并非鼓励大家盲目加班,而是倡导高效工作,拒绝无效忙碌,不要让项目进度因低效受影响,也别把精力浪费在和苏州同事拼打卡时长上,提倡更高的人效比;考虑到两地地域和交通差异,相信大家会找最适合自己发挥的工作方式(比如按时下班后1小时到家晚饭后继续未竟工作等..)大家在遵守公司规章的情况下尽情地体现自己的能力价值,为MOV!和深圳公司争光我们在这边才能更安心更有信心的工作下去;请客BU长、名部门长、项目管理和各业务单元负责人,全面梳理团队情况,及时评估成员工作负荷与成果质量,坚决清退划水害虫痕疫,践行公司价值观,相互监督,防止管理漏洞及渎职。感谢人家的理解,也请人家多担待我的直言不讳……
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务