A.Fate

求次短路方案数.

这题有点小水了,好像之前做过.

具体的方案显然是 DP,考虑枚举当前每一个路径长度,假如比最短路更优则覆盖最短路,之前的最短路用来覆盖次短路. 否则如果比次短路更优,则直接覆盖次短路.

方案数的话考虑一样的方法维护,只是在遇到相等的路径长时使方案数加一即可.

考试的时候把转移写在最短路里面了,所以错了一遍,因为这样是不完全更新,所以要拉到外面跑一遍.

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int p=1e9+7;
vector<int>e[200001];
int dis[200001],f[2][200001];
struct node{
int id,dis;
bool operator <(const node& A)const{
return dis>A.dis;
}
};
priority_queue<node>q;
void dij(int s){
memset(dis,0x3f,sizeof dis);
dis[s]=0;
q.push({s,dis[s]});
while(!q.empty()){
node u=q.top();
q.pop();
if(dis[u.id]!=u.dis){
continue;
}
for(int i:e[u.id]){
if(dis[i]>dis[u.id]+1){
dis[i]=dis[u.id]+1;
q.push({i,dis[i]});
}
}
}
}
struct node_{
int id,dis;
bool operator <(const node_ &A)const{
return dis<A.dis;
}
}no[200001];
signed main(){
// freopen("Fate9.in","r",stdin);
int n,m,s,t;
scanf("%lld %lld %lld %lld",&n,&m,&s,&t);
for(int i=1;i<=m;++i){
int u,v;scanf("%lld %lld",&u,&v);
e[u].push_back(v);
e[v].push_back(u);
}
dij(s);
for(int i=1;i<=n;++i){
no[i].id=i;
no[i].dis=dis[i];
}
sort(no+1,no+n+1);
f[0][s]=1;
for(int k=0;k<=1;++k){
for(int i=1;i<=n;++i){
for(int j:e[no[i].id]){
if(dis[j]==dis[no[i].id]+1){
f[k][j]+=f[k][no[i].id];
f[k][j]%=p;
}
if(k==0 and dis[no[i].id]+1==dis[j]+1){
f[1][j]+=f[0][no[i].id];
f[1][j]%=p;
}
}
}
}
printf("%lld",f[1][t]%p);
}

B.EVA

首先,把区间左端点放在一条鱼身上一定比较优,考虑到这个题 \(n\) 不是很大,可以枚举一遍左端点放在哪条鱼上.

其次,对于其他的鱼,可以考虑用相对速度算出它和当前鱼的相遇和离开时间,相遇时加上贡献,离开时减去贡献,计算途中最大值即可.

需要注意的是 \(v_{i}=v_{j}\) 时这么干会除以零,因为相对静止所以遇到这样的鱼直接在最初判一下就行了.

#include<bits/stdc++.h>
using namespace std;
const long double eps=1e-7;
int n,a,ans;
struct fish{
int w,x,v;
}f[3001];
int main(){
scanf("%d %d",&n,&a);
for(int i=1;i<=n;++i){
scanf("%d %d %d",&f[i].w,&f[i].x,&f[i].v);
}
for(int i=1;i<=n;++i){
map<double,int>mp;
int res=0;
for(int j=1;j<=n;++j){
if(f[i].v==f[j].v){
if(f[j].x>=f[i].x and f[j].x-f[i].x<=a){
res+=f[j].w;
}
}
else{
double l=(f[i].x-f[j].x)*1.0/(f[j].v-f[i].v);
double r=(f[i].x-f[j].x+a)*1.0/(f[j].v-f[i].v);
if(r-l<eps) swap(l,r);
if(r>=0){
l=max(l,0.0);
mp[l]+=f[j].w;
mp[r+eps]-=f[j].w;
}
}
}
ans=max(ans,res);
for(auto i=mp.begin();i!=mp.end();i++){
res+=i->second;
ans=max(ans,res);
}
}
printf("%d\n",ans);
}

C.嘉然登场

考虑一种策略:每次在插入 \(x\) 时,首先把所有 \(\ge k-x\) 的数全部放进去(也就是从大到小放),会发现,放完了之后,现在没放的数都是 \(i+x\lt k\) 的,因此全都不合法,而我们已经放入的数全部都是合法的.

新放的数不能与任何一个已经放过的 \(\le \lfloor\frac{k}{2}\rfloor\) 的数相邻,因此考虑插空算方案书,乘法原理算一下即可.

(\(e\) 是空位数量)

\[x(\ge \lfloor\frac{k}{2}\rfloor) C^{e-1}_{cnt_{x}+s-1},e=e+cnt_{x}
\]
\[x(\lt \lfloor\frac{k}{2}\rfloor) C^{cnt_{x}}_{e},e=e-cnt_{x}
\]
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int p=998244353;
int n,m,ans=1;
int a[200001],inv[200001];
signed main(){
cin>>n>>m;
for(int i=1;i<=n;++i){
cin>>a[i];
}
sort(a+1,a+n+1);
int l=1,r=n;
for(int i=1;i<=n;++i){
ans=ans*(i-2*(l-1))%p;
if(a[l]+a[r]>=m){
r--;
}
else{
l++;
}
}
inv[0]=inv[1]=1;
for(int i=2;i<=n;++i){
inv[i]=(p-p/i)*inv[p%i]%p;
}
a[0]=a[n+1]=-1;
int iv=1,cnt=1;
for(int i=1;i<=n+1;++i){
if(a[i]!=a[i-1]){
ans=ans*iv%p;
iv=cnt=1;
}
else{
cnt++;
iv=iv*inv[cnt]%p;
}
}
cout<<ans<<endl;
}

D.Clannad

暑假集训CSP提高模拟11的更多相关文章

  1. JZOJ 【NOIP2016提高A组集训第16场11.15】兔子

    JZOJ [NOIP2016提高A组集训第16场11.15]兔子 题目 Description 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3 ...

  2. JZOJ 【NOIP2016提高A组集训第16场11.15】SJR的直线

    JZOJ [NOIP2016提高A组集训第16场11.15]SJR的直线 题目 Description Input Output Sample Input 6 0 1 0 -5 3 0 -5 -2 2 ...

  3. 【NOIP2015模拟11.5】JZOJ8月5日提高组T2 Lucas的数列

    [NOIP2015模拟11.5]JZOJ8月5日提高组T2 Lucas的数列 题目 PS:\(n*n*T*T<=10^{18}\)而不是\(10^1*8\) 题解 题意: 给出\(n\)个元素的 ...

  4. 【NOIP2015模拟11.5】JZOJ8月5日提高组T1 俄罗斯套娃

    [NOIP2015模拟11.5]JZOJ8月5日提高组T1 俄罗斯套娃 题目 题解 题意就是说 将1~\(n\)排列,问有多少种方案使得序列的逆序对个数小于\(k\) 很容易想到DP 设\(f[i][ ...

  5. 【NOIP2015模拟11.2晚】JZOJ8月4日提高组T2 我的天

    [NOIP2015模拟11.2晚]JZOJ8月4日提高组T2 我的天 题目 很久很以前,有一个古老的村庄--xiba村,村子里生活着n+1个村民,但由于历届村长恐怖而且黑暗的魔法统治下,村民们各自过着 ...

  6. 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换

    [NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ...

  7. 【NOIP2015模拟11.4】JZOJ8月6日提高组T1 刷题计划

    [NOIP2015模拟11.4]JZOJ8月6日提高组T1 刷题计划 题目 题解 题意 有\(n\)道题,编号为1~\(n\) 给出\(m\)次操作 每次操作有3种类型 1 \(x\) 表示交了\(A ...

  8. 【NOIP2015模拟11.5】JZOJ8月5日提高组T3 旅行

    [NOIP2015模拟11.5]JZOJ8月5日提高组T3 旅行 题目 若不存在第\(k\)短路径时,输出"Stupid Mike" 题解 题意 给出一个有\(n\)个点的树 问这 ...

  9. 2015UESTC 暑假集训总结

    day1: 考微观经济学去了…… day2: 一开始就看了看一道题目最短的B题,拍了半小时交了上去wa了 感觉自己一定是自己想错了,于是去拍大家都过的A题,十分钟拍完交上去就A了 然后B题写了一发暴力 ...

  10. STL 入门 (17 暑假集训第一周)

    快速全排列的函数 头文件<algorithm> next_permutation(a,a+n) ---------------------------------------------- ...

随机推荐

  1. ABC347

    A link 很简单 遍历,判断模\(k\)是否为\(0\),如果为\(0\),输出\(a_i/k\). 点击查看代码 #include<bits/stdc++.h> using name ...

  2. activity向上/向下一个页面发送数据

    向下一个活动发送数据 一般使用bundle(捆) 使用方法 创建并准备发送数据 //这里是上一个页面 Intent intent = new Intent(this,class); //新建意图 Bu ...

  3. emojiCTF2024

    emojiCTF2024 WEB http 题目:​​ 思路: 修改 UA 头为 EMOJI_CTF_User_Agent_v1.0:User-Agent: EMOJI_CTF_User_Agent_ ...

  4. web3 产品介绍 etherscan 区块链浏览器 将抽象的数据和理论可视化,小白也能看懂区块链

    Etherscan是一个广泛使用的以太坊区块链浏览器和分析平台,它为用户提供了全面的区块链数据查询和交易分析功能.在本文中,我们将介绍Etherscan的主要特点和功能,以及如何使用它来浏览以太坊区块 ...

  5. 【Vue】图片裁剪功能支持

    一.效果展示: 1.表单的图片上传项: - 新增时默认一个空白Input框 - 更新时展示以往上传存放的图片, - 点击[查看]浏览完整大小 - 点击[删除]清空src地址,重新上传新照片 2.裁剪框 ...

  6. 强化学习中经典算法 —— reinforce算法 —— (进一步理解, 理论推导出的计算模型和实际应用中的计算模型的区别)

    在奖励折扣率为1的情况下,既没有折扣的情况下,reinforce算法理论上可以写为: 但是在有折扣的情况下,reinforce算法理论上可以写为: 以上均为理论模型. ================ ...

  7. 运行openai的gym代码报错提示import pyglet,安装后依然报错:ImportError: sys.meta_path is None, Python is likely shutting down

    运行代码: import gym def cartpole(): environment = gym.make('CartPole-v1') environment.reset() for _ in ...

  8. B站基于Apache DolphinScheduler的一站式大数据集群管理平台(BMR)初窥

    一.背景 大数据服务是数据平台建设的基座,随着B站业务的快速发展,其大数据的规模和复杂度也突飞猛进,技术的追求也同样不会有止境. B站一站式大数据集群管理平台(BMR),在千呼万唤中孕育而生.本文简单 ...

  9. 【开启报名】同学看过来,Apache DolphinScheduler开源之夏课题任务正式发布!

    如果你还拥有着一张有效的"学生证",在这个充满机遇的夏天,我们诚邀你加入一个充满挑战和机遇的开源冒险--开源之夏. 这不仅是一个简单的编程开发活动,假如你成功参加并结项之后,还能获 ...

  10. JDK、JRE和JVM简述

    JDK(Java Development Kit) JDK是Java开发环境的核心组件,包括:Java编译器.JRE(Java运行环境)JavaDoc文档生成器和其他一些工具. JDK是Java程序员 ...