字节跳动ZJ1->附加题(跳房子) !!

附加题

http://www.nowcoder.com/questionTerminal/58b04ed2865f4ff4921290f1bd4ee486

1. 题目意思[写博客为了记录一下这道题我很困扰]

1.老实说,题目意思我都没读懂。。。按照例子走,刚开始的1算访问次数,但不算移动次数的。对于移动的思路我是一点没理清楚。。还想多了会不会有pi到不了后面的情况。。肯定不会啊,题目都没说到不了输出情况测试数据肯定不会那么邪门。
2. 观摩大佬的思路皮皮浔,此时p[i]门变为奇数次,其他的暂时任为偶数次,因为是奇数嘛其他都是偶数/原本的0次,所以再回去就变为了第一次到n-1移动的次数减去第一次到p[n-1]的次数。关于加两次1,第一次是n-1的奇数次跳转,第二次是偶数次到达目标的跳转。
图片说明

2.源代码

#include <iostream>
using namespace std;

long long p[1001], dp[1001], n;//全局变量初始化为0  题目意思应该是说刚开始的房间1不算移动 此时 但计入第一次访问
const long long mod = 1e9 + 7;

int main (){
    cin >> n;
    for (int i = 1; i<= n; i++) 
        cin >> p[i];
    for (int i = 2; i<= n+1; ++i) //2到n+1 这边房间数一定>=2
        dp[i] = (2 * dp[i-1] - dp[p[i-1]] + 2) % mod;
    cout << (dp[n + 1] < 0 ? dp[n + 1] + mod : dp[n + 1]);
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-03 17:30
点赞 评论 收藏
分享
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利&nbsp;有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的&nbsp;真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
点赞 评论 收藏
分享
评论
21
2
分享

创作者周榜

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