首页 > 其他分享 >CF1472C Long Jumps题解

CF1472C Long Jumps题解

时间:2024-02-17 21:27:09浏览次数:31  
标签:CF1472C int 题解 Jumps 位置 long include 方法

【题目分析】

本题有两个方法,

方法一:每一个位置可得的分分别求出,打擂找出最大(可得部分分)

方法二:从后往前求可得的分数,以避免一些不必要的重复。

【设计程序】

方法一:

#include<bits/stdc++.h>
#include<iostream>
#include<stdio.h>
#include<cstdio>
#include<queue>
using namespace std;
const int N = 2 * 1e5 + 5;
int a[N];
int n;
long long score(int x)//求这个位置出发可得的分
{
	long long ans = 0;
	while(x <= n)//当x还在n的范围中时
	{
		ans += a[x];//加这个位置的值
		x += a[x];//把x标到下一个位置
	}
	return ans;//返回得分
}
int main()
{
	int p;
	scanf ("%d", &p);//输入组数
	while (p--)
	{
		long long maxn = 0;
		scanf ("%d", &n);//输入数据个数
		for (int i = 1;i <= n; i++)//输入数据
			scanf ("%d", a + i);
		for (int i = 1;i <= n; i++)//从每一个位置开始
			maxn = max(maxn, score(i));//求最大值
		printf ("%d\n", maxn);//输出最大值
	}
	return 0;
}

方法二:

#include<bits/stdc++.h>
#include<iostream>
#include<stdio.h>
#include<cstdio>
#include<queue>
using namespace std;
const int N = 2 * 1e5 + 5;
int a[N];
long long b[N];//b[i]表示从i出发可得的分数
int n;
int main()
{
	int p;
	scanf ("%d", &p); //输入组数
	while (p--)
	{
		scanf ("%d", &n); //输入数据个数
		for (int i = 1;i <= n; i++)//输入数据
			scanf ("%d", a + i);
		for (int i = n;i >= 1; i--)
		{
			if (i + a[i] > n)
			//如果后一个位置在n的范围外
				b[i] = a[i];//此位置的得分为本位置的值
			else//如果在n中
				b[i] = a[i] + b[i + a[i]];
				//本位置的值加上下个位置的得分
		}
		long long maxn = b[1];
		for (int i = 2;i <= n; i++)//打擂找最大
			maxn = max(maxn, b[i]);
		printf ("%d\n", maxn);//输出最大值
	}
	return 0;
}

【调试代码】

  1. 测试样例
  2. 自测数据(特殊值,边界值)

数据:

4

5

0 0 0 0 0

3

3 2 1

1

1000

5

1 1 1 1 1

标签:CF1472C,int,题解,Jumps,位置,long,include,方法
From: https://www.cnblogs.com/Assassins-Creed/p/18018410

相关文章

  • CF1196B Odd Sum Segments题解
    【问题分析】本题考了奇数。由此想到以下定律:奇数+偶数=奇数;奇数+奇数=偶数;偶数+偶数=偶数;所以偶数可以忽略不计,只有奇数可以对结果产生影响,所以我们只要注意奇数即可。经过思考可得奇数的个数至少为$k$个且比$k$多的个数为偶数,此时多出的奇数可组成偶数,对结果不产生......
  • P2036 [COCI2008-2009#2] PERKET题解
    【问题分析】分析题目可得此问题为01背包问题因此题数据较小所以可用枚举每一样物品选或不选的方法来写【设计程序】#include<bits/stdc++.h>#include<iostream>#include<stdio.h>#include<cstdio>#include<queue>usingnamespacestd;constintN=10+5;struct......
  • P1162 填涂颜色题解
    【问题分析】分析题目可得此问题为连通块问题因此题枚举被包围的‘0’较难所以可用枚举每一个不被包围的‘0’【设计程序】#include<bits/stdc++.h>#include<iostream>#include<stdio.h>#include<cstdio>#include<queue>usingnamespacestd;constintN=30+5;i......
  • P2249 【深基13.例1】查找题解
    【问题分析】本题有n个数(n>10^6)n很大,查找m个数(m≤10^5),数最大为(10^9)方法一:用顺序查找的话时间复杂度为:O(n*m)会超时,只能得部分分;方法二:用桶排时间复杂度为O(n)+O(m),但是因为数最大为(109)空间复杂度为:O(109);方法三:用二分查找,时间复杂度为:O(m*logn),空间复杂度为O(n)。综合以......
  • P8248 简单数列 题解
    首先,圈重点:$1\len\le500$所有元素在$1\sim4$之间任意连续的连续子串不相同只要输出一种答案即可于是我们可以得到的是:由第一点和第二点可以看出此题可以写搜索解决。由第三点我们可以得到一种剪枝方式,就是如果目前数字放入后会产生相同的连续的连续子串。由第四点......
  • P1380 T型骨牌 题解
    本题每个位置有$5$种可能,据题中$n,m$均小于五,所以可以用搜索直接过。上代码#include<cstdio>usingnamespacestd;boolmp[15][15];intn,m,ans;intdt[4][5][2]={{{-1,-1},{0,-1},{1,-1},{0,0},{0,1}},{{-1,0},{0,0},{1,-1},{1,0},{1,1}},{{0,......
  • P1686 挑战 题解
    本题就是要找到最短的捷径。注意事项:捷径必须是直线。要求捷径最短而非总路程最短。捷径不与原有的路重合既然在同一直线上,则该捷径的起点与终点的横坐标或纵坐标相等。要把横坐标或纵坐标相同的聚在一起只需要排个序即可。捷径最短的话(以横坐标相等举例),只需要以$x$为第......
  • P1541 [NOIP2010 提高组] 乌龟棋题解
    有两种方法,代码注释都很详细了直接上代码一:记忆化搜索#include<bits/stdc++.h>usingnamespacestd;intt[15];intn,m;inta[400];intmp[45][45][45][45];//mp[i][j][k][l]表示1号用i张,2号用j张,3号用k张,4号用l张的情况下,最多能拿多少分intdfs(intstep,intw)//step......
  • TopCoder SRM478C RandomApple 题解
    题意:有\(k\)种苹果和\(n\)个箱子,每个箱子中有一些苹果,先等概率选取\(n\)个箱子组成集合的非空子集,再从选出的苹果中随机选一个,问每种苹果被选中的概率是多少箱子\(i\)有\(a_{i,j}\)个第\(j\)种苹果,第\(i\)个箱子的总苹果数\(siz_i=\sum\limits_{j=1}^ka_{i,j}\),苹果总数\(sum=\su......
  • 无限酒店 题解
    题目链接由于间隔不变,对于下面\(3\)个操作,只需记录起始位置与间隔即可。对于无数人到达酒店:所有位置的起始点\(\times2\),间隔\(\times2\),新的团队起始点为\(1\),间隔为\(2\)。对于\(k\)个人到达酒店:所有点的起始点\(+k\),间隔不变,新的团队起始点为\(0\),间隔为\(1\)......