cf1552F. Telepanting

题意:

在一个坐标轴上,有n个传送门,格式为:xi,yi,si,可以从xi传送到yi,si表示状态,如果si为0,到位置xi时不会传送,si变为1.如果到达xi时si为1,则触发传送,si变为0.
问到达xn+1需要走的距离是多少?

题解:

我一开始就是模拟做,但是必然会超时,所以需要我们去寻找其他的性质
当我们到达一个xi时,在此之前的所有传送位置(不含xi)必然都是激活状态(即si=1)

为什么?如果之前有个传送位置pos不是激活,说明你在经过pos之前,pos是激活状态,那你经过pos就要被传送到前面,pos变为未激活,然后经过他又变成激活。

.这说明在yi到xi这段区间内的所有传送位置我们都是要经历一遍。
我们设q[i]:表示触发了第i个传送,又回到位置x[i]所走的路径
sum[i]:表示触发前i个传送所要走的路径,即q[i]的前缀和
q[i]如何求?
q[i]就是从y[i]走到x[i]这段路径,再加上这段路程上的所有q[pos],pos为这段区间的传送门,这个可以用sum来表示
最后统计答案时,先计算基本路程x[n]+1,以及每个激活的传送门的路程

代码:

// Problem: F. Telepanting
// Contest: Codeforces - Codeforces Global Round 15
// URL: https://codeforces.com/contest/1552/problem/F
// Memory Limit: 256 MB
// Time Limit: 2000 ms
// By Jozky#include <bits/stdc++.h>
#include <unordered_map>
#define debug( a, b ) printf ( "%s = %d\n", a, b );
using namespace std;
typedef long long          ll;
typedef unsigned long long ull;
typedef pair<int, int>     PII;
clock_t                    startTime, endTime;
// Fe~Jozky
const ll                                       INF_ll  = 1e18;
const int                                      INF_int = 0x3f3f3f3f;
void                                           read (){};
template <typename _Tp, typename... _Tps> void read ( _Tp &x, _Tps &...Ar )
{x         = 0;char c    = getchar ();bool flag = 0;while ( c < '0' || c > '9' )flag |= ( c == '-' ), c = getchar ();while ( c >= '0' && c <= '9' )x = ( x << 3 ) + ( x << 1 ) + ( c ^ 48 ), c = getchar ();if ( flag )x = -x;read ( Ar... );
}
template <typename T> inline void write ( T x )
{if ( x < 0 ){x = ~( x - 1 );putchar ( '-' );}if ( x > 9 )write ( x / 10 );putchar ( x % 10 + '0' );
}
void rd_test ()
{#ifdef ONLINE_JUDGE
#elsestartTime = clock ();freopen ( "in.txt", "r", stdin );
#endif
}
void Time_test ()
{#ifdef ONLINE_JUDGE
#elseendTime = clock ();printf ( "\nRun Time:%lfs\n",(double)( endTime - startTime ) / CLOCKS_PER_SEC );
#endif
}
const int maxn = 3e5 + 9;const int mod  = 998244353;
ll        sum[maxn];
ll        q[maxn];
ll        x[maxn];
ll        y[maxn];
ll        s[maxn];
int       main ()
{// rd_test();int n;cin >> n;int maxx = 0;for ( int i = 1; i <= n; i++ ){read ( x[i], y[i], s[i] );//        read ( a[i], a[i].y, a[i].s );int pos = lower_bound ( x + 1, x + 1 + i, y[i] ) - x;// cout << "pos=" << pos << endl;q[i]    = ( x[i] - y[i] + sum[i - 1] - sum[pos - 1] + mod ) % mod;sum[i]  = ( sum[i - 1] + q[i] ) % mod;}ll ans = ( x[n] + 1 ); //必走的路for ( int i = 1; i <= n; i++ ){if ( s[i] )ans = ( ans + q[i] + mod ) % mod;}printf ( "%lld", ( ans % mod + mod ) % mod );return 0;// Time_test();
}

cf1552F. Telepanting相关推荐

  1. 思维dp ---- 复杂状态找中间状态作为dp状态 1552F - Telepanting

    题目链接 题目大意: 有个蚂蚁从000号点要到xn+1x_n+1xn​+1的位置. 在x0,x1,x2,x3,.....,xn+1,xnx_0,x_1,x_2,x_3,.....,x_{n+1},x_ ...

最新文章

  1. Flask学习之路(一)--初识flask
  2. 力扣(LeetCode)刷题,简单题(第19期)
  3. 【Java源码分析】HashTable源码分析
  4. [转]linux 下自动登录到ftp
  5. 硝烟四起的云服务双十一促销大战,谁更便宜?
  6. http默认超时时间_Bof 是一个HTTP客户端,旨在尽可能方便用户使用
  7. html语言中括号怎么打,HTML语言中括号(尖括号)的字符编码
  8. python token 访问控制_python 产生token及token验证
  9. android 动态设置textview的边距,添加边距为动态的Android的TextView(Adding Margins to a dynam...
  10. python特征数据类型及常用操作对比_更高效的利用Jupyter+pandas进行数据分析,6种常用数据格式效率对比!...
  11. ABP后台服务之作业调度Quartz.NET
  12. python面试文件操作_python基础-三分钟搞定面试官爱问的【文件操作】
  13. 【redis】redis的bind配置
  14. 【LG3244】[HNOI2015]落忆枫音
  15. 洛谷——P2342 叠积木
  16. GroovyHelp
  17. 大数据与云计算之间的联系,一篇文章搞明白!
  18. SOAP实例入门(转)
  19. 券商卖的雪球票息高,券商赚的什么钱?(雪球原理入门)
  20. 改进的判定条件覆盖讲解和真值表书写

热门文章

  1. 影子的变化情况到底如何?和太阳又有什么关系?
  2. 轮子,辛苦你了。 | 今日最佳
  3. 想转行人工智能?哈佛博士后有话说!
  4. 数据告诉你,抖音是如何在半年之内逆袭的
  5. 推荐系统相关算法(1):SVD
  6. linux内核分析与移植,内核分析移植
  7. 架构师讲解Java中websocket的应用
  8. python +appium实现原理_python_appium使用原理
  9. python用pandas提取行列_python- pandas 不删除符合条件的行和列
  10. python编译安装没有c扩展_为什么在安装simplejson时得到“C扩展无法编译”?