虎牙C++笔试分享

编程三道题
分享下第三题的水dp写法
求0-n之间二进制内没有连续三个1的数的个数
#include <iostream>
using namespace std;
int v[100];
int dp[100][3];
int dfs(int len,int flag,bool limit){
    if (flag == 3) return 0;
    if (len == 0) return 1;
    if (!limit&&dp[len][flag] != -1) return dp[len][flag];
    int maxx = limit ? v[len] : 1;
    int cnt = 0;
    for (int i = 0; i <= maxx; i++){
        if (i == 0){
            cnt += dfs(len-1,0,limit&&i == v[len]);
        }
        else{
            cnt += dfs(len-1, flag+1 , limit&&i == v[len]);
        }
    }
    return limit ? cnt : dp[len][flag] = cnt;
}
int solve(long long x){
    memset(v, 0, sizeof(v));
    int k = 0;
    while (x){
        v[++k] = x % 2;
        x >>=1;
    }
    return dfs(k, 0, true);
}
int main(){
    memset(dp, -1, sizeof(dp));
    long long a;
    cin >> a;
    cout<<solve(a)<<endl;
    return 0;
}

#虎牙直播##笔试题目##题解#
全部评论
学***佬,请问还有什么题吗,方便透露一下,练练手,感谢~ #include <iostream> using namespace std; int main() {     int n;     cin>>n;     int num = 0;     for(int i = 0;i <= n;i++)     {         for(int j = i;j > 0;j>>=1)         {             int temp1 = j & 1;             j>>=1;             cout<<j<<":"<<temp1<<endl;             int temp2 = j & 1;             j>>=1;             cout<<j<<":"<<temp2<<endl;             int temp3 = j & 1;             cout<<j<<":"<<temp3<<endl;             if(temp1 == 1 && temp2 == 1 && temp3 == 1)             {                 num++;             }         }     }     cout<<num;     return 0; }
点赞 回复 分享
发布于 2019-04-22 09:32
虎牙大佬
点赞 回复 分享
发布于 2018-11-01 16:31
没人暖贴的嘛  桑心   回复0 | 赞 1 | 浏览302
点赞 回复 分享
发布于 2018-09-14 21:18

相关推荐

03-03 15:53
已编辑
黑龙江大学 Java
在当前开源项目极为丰富的背景下,付费资源并不一定意味着最前沿的技术优势,在具体执行层面展示出自己的独特价值,才是简历上最重要的加分项。1.&nbsp;WebMCP&nbsp;—&nbsp;让网站主动告诉&nbsp;AI&nbsp;该怎么操作AI&nbsp;操作浏览器的方案一直靠&quot;猜&quot;——截图识别、DOM&nbsp;解析,错误率&nbsp;15-30%。WebMCP&nbsp;反过来,让网站自己声明能做什么,AI&nbsp;直接调用结构化接口,准确率接近&nbsp;100%。Chrome&nbsp;Canary&nbsp;已实装。企业内部系统的&nbsp;WebMCP&nbsp;适配目前几乎没人做,是明确的蓝海。推荐理由:简历上写的不是&quot;我会用某个框架&quot;,而是&quot;我在标准刚发布时就做了企业适配&...
书海为家:#人脑vsAI# 尽管深度学习的最初灵感来源于人类的大脑,但二者的运作方式截然不同:深度学习所需要的数据量远比人脑所需要的多得多。可是一旦经过大数据训练,它在相同领域的表现将远远超过人类(尤其是在数字的量化学习,例如挑选某人最可能购买的产品,或从100万张脸中挑选最匹配的一张)——相对来说,人类在同一时间内只能把注意力放在少数几件事情上面,而深度学习算法却可以同时处理海量信息,并且发现在大量数据背后的模糊特征之间的关联,这些模糊特征不仅复杂而且微妙,人类往往无法理解,甚至可能不会注意到。 虽然深度学习拥有人类所缺乏的并行处理海量数据的“绝技”,但不具备人类在面对决策时独一无二的汲取过去的经验、使用抽象概念和常识的能力。 与人类相比,深度学习想要充分发挥作用,离不开海量的相关数据、单一领域的应用场景以及明确的目标函数,这三项缺一不可,如果缺少其中任何一项,深度学习将无用武之地。
AI求职实录
点赞 评论 收藏
分享
评论
点赞
12
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务