A

这题是很有意思的一个题,思路就是你考虑kt的位置只可能在四个角,因为这种情况下,他的距离才会最远对吧,所以你就暴力找另一个人fengwu的点的位置,然后计算他们之间的距离然后你求一个\(\max\)即可,然后记录一下这些\(\max\)的值,最后排个序就好了。

代码:

# include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 5010;
int a[N*N];
int dis(int a,int b,int c,int d)
{
return abs(a-b)+abs(c-d);
}
signed main (){
int n,m;
scanf("%lld%lld",&n,&m);
int tot = 0;
for(int i = 1;i <= n;i++)
{
for(int j = 1;j <= m;j++)
{
// int x = (i-1)*(j-1);
// cout << x << endl;
int mx = max(dis(1,i,1,j),max(dis(1,i,m,j),max(dis(n,i,1,j),dis(n,i,m,j))));
a[++tot] = mx;
}
}
sort(a+1,a+tot+1);
for(int i = 1;i <= tot;i++)
{
printf("%lld ",a[i]);
}
return 0;
}

有可能会问,你如何考虑\(k\)这个东西呢,你考虑,我排序的过程就是对\(k\)个进行筛选,筛选过后的结果不会对最大值的最小值产生影响,所以不需要考虑k。

B

好题,这是一个很好很好的题。

\(10pts\):

显然,对于\(10pts\),这可以直接爆搜全排列,然后暴力计数值。,代码:

# include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 5010;
const int mod = 998244353;
int s[N],p[N],vis[N];
int jc[N];
int n;
int f(int n,int p[],int s[])
{
int ret=p[1];
for(int i=2;i<=n;i++)
{
if(s[i-1]==1)ret=max(ret,p[i]);
else ret=min(ret,p[i]);
}
return ret;
}
int ans = 0;
void dfs(int dep)
{
if(dep == n+1)
{
for(int i = 1;i <= n;i++)
{
// cout << p[i] << " ";
}
// if(p[n] == 3) tot++;
// cout << endl;
ans += f(n,p,s);
ans %= mod;
return ;
}
for(int i = 1;i <= n;i++)
{
if(!vis[i])
{
vis[i] = 1;
p[dep] = i;
dfs(dep+1);
vis[i] = 0;
}
}
}
int qpow(int a,int b)
{
int ans = 1;
while(b != 0)
{
if(b & 1)
{
ans = ans*a%mod;
}
a = a*a%mod;
b >>= 1;
}
return ans%mod;
}
int ny(int n)
{
return qpow(n,mod-2);
}
signed main (){
scanf("%lld",&n);
for(int i = 1;i <= n-1;i++)
{
scanf("%lld",&s[i]);
}
jc[0] = 1;
for(int i = 1;i <= n;i++)
{
jc[i] = jc[i-1]*i%mod;
}
int flag = 0;
for(int i = 2;i <= n-1;i++)
{
if(s[i] < s[i-1])
{
flag = 1;
break;
}
}
int cnt = 0;
if(flag == 0)
{
for(int i = 1;i <= n-1;i++)
{
if(s[i] == 1) cnt++;
}
}
if(n <= 10)
{
dfs(1);
// cout << tot << endl;
printf("%lld\n",ans%mod);
}
else
{
if(flag == 0)
{
int res = 0;
if(cnt == 1)
{
res = jc[n-1]*(ny(2)*((n*(n+1)%mod+2)%mod)%mod)%mod;
}
printf("%lld\n",res);
}
}
return 0;
}

\(100pts:\)

你考虑转化问题,你考虑算出他的答案,然后呢你去计算这个数列会产生这个答案的排列方式是多少,最后他对答案产生的贡献就是排列方式\(\times\)答案。

那么你考虑如何计算这个这个排列方式,我们对于每个数都去动态计算这个数列离散化过后的值,什么意思呢,看下面这一组例子:

\[5\; \;\;1 \:\;\;4 \:\;\;2 \:\;\;3
\]

一开始放入一个\(5\),离散化之后的数列是这样的:

\[1
\]

接下来放入\(1\),离散化之后是

\[2 \; \;\;\;1
\]

接下来放入\(4\),\(4\)比\(1\)大,比\(5\)小,所以他是第二小的,离散化后是:

\[3 \; \; \; 1 \; \; \; 2
\]

........

最后的结果就是:

\[5 \;\;\; 1 \;\;\; 4 \;\;\; 2 \;\;\; 3
\]

你考虑这个跟之前没变的是一样的。

那么我们考虑逐位计算,用\(dp\)去转移。

设定\(dp_{i,j}\)表示表示前\(i\)位,插入这个数字过后得到的答案,显然得到以下转移方程:

\[
dp_{i,j} =
\begin{cases}
\sum
\end{cases}
\]

2024/9/16 CSP-S模拟赛试题的更多相关文章

  1. 16.1117 NOIP 模拟赛

    水灾(sliker.cpp/c/pas) 1000MS  64MB 大雨应经下了几天雨,却还是没有停的样子.土豪CCY刚从外地赚完1e元回来,知道不久除了自己别墅,其他的地方都将会被洪水淹没. CCY ...

  2. 10.16 NOIP模拟赛

    目录 2018.10.16 NOIP模拟赛 A 购物shop B 期望exp(DP 期望 按位计算) C 魔法迷宫maze(状压 暴力) 考试代码 C 2018.10.16 NOIP模拟赛 时间:2h ...

  3. [NOIP2018模拟赛10.16]手残报告

    [NOIP2018模拟赛10.16]手残报告 闲扯 炉石乱斗模式美滋滋啊,又颓到好晚... 上来T2先敲了树剖,看T1发现是个思博DP,然后没过大样例,写个暴力发现还是没过大样例!?才发现理解错题意了 ...

  4. 2017.1.16【初中部 】普及组模拟赛C组总结

    2017.1.16[初中部 ]普及组模拟赛C组 这次总结我赶时间,不写这么详细了. 话说这次比赛,我虽然翻了个大车,但一天之内AK,我感到很高兴 比赛 0+15+0+100=115 改题 AK 一.c ...

  5. @省选模拟赛03/16 - T3@ 超级树

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 一棵 k-超级树(k-SuperTree) 可按如下方法得到:取 ...

  6. 2019.3.16 noiac的原题模拟赛

    RT,这太谔谔了,我不承认这是模拟赛 但是虽然是搬了三道题,题目本身也还能看,就这么着吧 (怎么机房里就我一道原题都没做过啊 T1 CF24D Broken Robot 比较简单地列出式子之后,我们发 ...

  7. 2018.10.16 NOIP模拟赛解题报告

    心路历程 预计得分:\(100 + 100 + 20 = 220\) 实际得分:\(100 + 100 + 30 = 230\) 辣鸡模拟赛.. T1T2都是一眼题,T3考验卡常数还只有一档暴力分. ...

  8. CSP模拟赛游记

    时间:2019.10.5 考试时间:100分钟(连正式考试时间的一半还没有到)题目:由于某些原因不能公开. 由于第一次接触NOIinux系统所以连怎么建文件夹,调字体,如何编译都不知道,考试的前半小时 ...

  9. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  10. 2014.7.8模拟赛【笨笨当粉刷匠】|bzoj1296 [SCOI]粉刷匠

    笨笨太好玩了,农田荒芜了,彩奖用光了,笨笨只好到处找工作,笨笨找到了一份粉刷匠的工作.笨笨有n条木板需要被粉刷.每条木板被分成m个格子,每个格子要被刷成红色或蓝色.笨笨每次粉刷,只能选择一条木板上一段 ...

随机推荐

  1. .NET8 Blazor 从入门到精通:(二)组件

    目录 Blazor 组件 基础 路由 参数 组件参数 路由参数 生命周期事件 状态更改 组件事件 Blazor 组件 基础 新建一个项目命名为 MyComponents ,项目模板的交互类型选 Aut ...

  2. 2. 基于MCU应用的EMC指南

    1. 硬件 主要的噪声感受器和发生器是印刷电路板(PCB)上的轨道和布线,特别是MCU附近的轨道和布线.因此,防止噪声问题的第一步行动涉及到PCB布局和电源设计.一般来说,MCU周围的元器件数量越少, ...

  3. JavaScript设计模式样例六 —— 抽象工厂模式

    抽象工厂模式(Abstract Factory Pattern) 定义:抽象工厂模式提供了一种方式,可以将一组具有同一主题的单独的工厂封装起来.或者说,是其他工厂的工厂.目的:提供一个创建一系列相关或 ...

  4. .NET 8 + Vue 3 极简 RABC 权限管理系统

    前言 在日常工作中,几乎每家公司都需要一个后台管理系统来处理各种任务.为了帮助大家快速搭建这样一个系统,给大家介绍一个基于最新技术 .NET 8 和前端框架 Vue 3 实现的极简 RABC(基于角色 ...

  5. LaTeX 常用引用标签前缀

    引用对象 标签前缀 Chapter ch Section sec Subsection sec Appendix app Figure fig Table tab List item itm Equa ...

  6. 啥是Session?

    什么是 Session 会话? 1.Session 就一个接口(HttpSession). 2.Session 就是会话.它是用来维护一个客户端和服务器之间关联的一种技术. 3.每个客户端都有自己的一 ...

  7. 待补 重要思考:求给无向图定向使得其变为DAG的方案数

    今天比赛考到了,不会,丢了 100 分. rk2,380 -> rk15,280 别问为什么 T4 没过,因为不会 T2. 方法一 \(O(3^n)\) 令 \(f_S\) 为子集 \(S\) ...

  8. GitHub Star 数量前 13 的自托管项目清单

    一个多月前,我们撰写并发布了这篇文章<终极自托管解决方案指南>.在那篇文章里我们深入探讨了云端服务与自托管方案的对比.自托管的潜在挑战.如何选择适合自托管解决方案,并深入介绍了五款涵盖不同 ...

  9. RxJS 系列 – Scheduler

    前言 大部分情况下, RxJS 都是用来处理异步执行的. 比如 Ajax, EventListener 等等. 但其实, 它也是可以同步执行的, 甚至 by default 它就是同步执行的 (下面会 ...

  10. /proc/vmalloc

    root@pita2_mr813_tina35:/# cat /proc/vmallocinfo 0xffffff80007d0000-0xffffff8000902000 1253376 load_ ...