不小心有咕掉了一段时间

这次考试咕掉的分数也是太多了

然后就是这次暴力完全没有打满

遗憾啊遗憾

T1

入阵曲

前面的题目背景故意引导我们去往矩阵快速幂的方向去想

然而半毛钱关系没有

其实就是维护前缀和

二维的

然后就有显然的 \(\mathcal O(n^4)\) 的暴力。

然而我这个 \(sb\) 在考试之前认为没有开 \(long\;long\) 的必要,然后就把 \(long \;long\) 给关了。

\(60\;->\;50\)

心态炸裂

\(\huge_{\text{以后我要是在打暴力关long long我就是dogge}}\)

然后正解就是可以压缩一维的计算。

就是对于每个余数进行记录就行。

之后就是一个优秀的 \(\mathcal O(n^3)\) 的算法。

其实我认为有点扫描线的感觉。

\(code:\)



#include<bits/stdc++.h>
using std::cout; using std::endl;
#define int long long
#define debug cout<<"debug"<<endl
#define freopen eat2 = freopen
#define scanf eat1 = scanf
namespace xin_io
{
#define gc() p1 == p2 and (p2 = (p1 = buf) + fread(buf,1,1<<20,stdin),p1 == p2) ? EOF : *p1++
#define scanf eat1 = scanf
#define freopen eat2 = freopen
char buf[1<<20],*p1 = buf,*p2 = buf;FILE *eat2;
inline void openfile() {freopen("t.txt","r",stdin);} inline void outfile(){freopen("o.txt","w",stdout);}
inline int get()
{
int s = 0,f = 1;register char ch = gc();
while(!isdigit(ch))
{if(ch == '-') f = -1;ch = gc();}
while(isdigit(ch))
{s = s * 10 + ch - '0';ch = gc();}return s * f;
}
}
using namespace xin_io; int eat1;
static const int maxn = 401,maxl = 1e6+10;
#define try(i,a,b) for(register signed i=a;i<=b;++i)
#define throw(i,a,b) for(register signed i=a;i>=b;--i)
namespace xin
{
int a[maxn][maxn];
int ans;
int n,m,k;
int he[maxn][maxn],b[maxl],cnt[maxl];
inline short main()
{
#ifndef ONLINE_JUDGE
openfile();
#endif
n = get(); m = get(); k = get();
try(i,1,n) try(j,1,m)
{
a[i][j] = get();
he[i][j] = he[i-1][j] + he[i][j-1] - he[i-1][j-1] + a[i][j];
}
// try(i,1,n){cout<<endl; try(j,1,m) cout<<he[i][j]<<' ';} cout<<endl;
try(i,0,n-1) try(j,i+1,n)
{
cnt[0] = 1;
try(t,1,m)
{
b[t] = (he[i][t] - he[j][t]) % k;
if(b[t] < 0) b[t] += k;
ans += cnt[b[t]]++;
}
try(t,1,m) cnt[b[t]] = 0;
}
cout<<ans<<endl;
return 0;
}
}
signed main() {return xin::main();}

码风逐渐扭曲

T2

遗憾的不是没有想出来看似简单的贪心正解。

而是没有打对自己的暴力。

我不是很擅长暴力的嘛

好吧

暴力就是对于每一个答案进行枚举

然后对于这个答案的方案进行暴力的枚举

然后进行 \(check\)。

之后发现 \(ok\) 的就可以 \(return \;0\) 了。

然后就可以愉快的 \(50pts\)

其实在 \(k==1\) 的部分可以打一个小胖收守皇宫

之后愉快 \(80pts\)

其实正解就是贪心

从深度大的开始枚举

如果这个点没有被守卫到那么就将他的 \(k\) 级祖先安排哨兵

就这?!

就这



#include<bits/stdc++.h>
using std::cout; using std::endl;
#define debug cout<<"debug"<<endl
#define freopen eat2 = freopen
#define scanf eat1 = scanf
namespace xin_io
{
#define gc() p1 == p2 and (p2 = (p1 = buf) + fread(buf,1,1<<20,stdin),p1 == p2) ? EOF : *p1++
#define scanf eat1 = scanf
#define freopen eat2 = freopen
char buf[1<<20],*p1 = buf,*p2 = buf;FILE *eat2;
inline void openfile() {freopen("t.txt","r",stdin);} inline void outfile(){freopen("o.txt","w",stdout);}
template<class type>inline type get()
{
type s = 0,f = 1;register char ch = gc();
while(!isdigit(ch))
{if(ch == '-') f = -1;ch = gc();}
while(isdigit(ch))
{s = s * 10 + ch - '0';ch = gc();}return s * f;
}
}
using namespace xin_io; int eat1;
#define try(i,a,b) for(register signed i=a;i<=b;++i)
#define m(c,num,size) memset(c,num,size)
static const int maxn = 1e6+10;
namespace xin
{
class xin_edge{public:int next,ver;}edge[maxn];
class xin_data
{
public:
int bian,d;
friend bool operator < (xin_data x,xin_data y)
{return x.d > y.d;}
}a[maxn];
int head[maxn],zhi = 0;
inline void add(int x,int y){edge[++zhi].ver = y; edge[zhi].next = head[x]; head[x] = zhi;}
int n,k,t;
int d[maxn];
bool vis[maxn],s[maxn];
inline void topo()
{
std::queue<signed>q;
q.push(1); a[1].d = 1; vis[1] = 1; d[1] = 1;
while(!q.empty())
{
register int x = q.front(); q.pop();
for(register int i=head[x];i;i=edge[i].next)
{
register int y = edge[i].ver;
if(!vis[y])
{
vis[y] = 1;
q.push(y);
a[y].d = a[x].d + 1;
d[y] = d[x] + 1;
}
}
}
}
bool ok = 0;
void dfs(int x,int fa,int cnt)
{
if(cnt > k) return ;
if(s[x]) {ok = 1;return;}
for(register int i=head[x];i;i=edge[i].next)
{
register int y = edge[i].ver;
if(y == fa) continue;
dfs(y,x,cnt+1);
}
}
void find(int x,int cnt)
{
s[x] = 1;
if(cnt == k or x == 1) {return;}
for(register int i=head[x];i;i=edge[i].next)
{
register int y = edge[i].ver;
if(d[y] >= d[x]) continue;
// cout<<"x = "<<x<<" a[x].d = "<<d[x]<<" y = "<<y<<" a[y].d = "<<d[y]<<endl;
find(y,cnt+1);
}
}
int ans = 0;
inline void work(int x)
{
ok = 0;
if(s[x]) {ok = 1;}
else
dfs(x,-1,0);
if(!ok)
s[x] = 1,find(x,0),ans++;
}
const int ms = 1e5;
inline short main()
{
#ifndef ONLINE_JUDGE
openfile();
#endif
n = get<signed>(); k = get<signed>(); t = get<signed>();
try(i,1,n-1)
{
register int x = get<signed>(),y = get<signed>();
add(x,y); add(y,x);
a[i].bian = i;
}
a[n].bian = n;
topo();
std::sort(a+1,a+n+1);
// try(i,1,n) cout<<a[i].bian<<' '<<a[i].d<<endl;
try(i,1,n)
work(a[i].bian);
cout<<ans<<endl;
return 0;
}
}
signed main() {return xin::main();}

T3

我用的背包

然后被某神笨认定假的。

然而不知道为什么我的code过了

既然假了,那就不写了。


这次真的咕了好多啊

[考试总结]noip模拟10的更多相关文章

  1. 2021.6.29考试总结[NOIP模拟10]

    T1 入阵曲 二位前缀和暴力n4可以拿60. 观察到维护前缀和时模k意义下余数一样的前缀和相减后一定被k整除,前缀和维护模数,n2枚举行数,n枚举列, 开一个桶记录模数出现个数,每枚举到该模数就加上它 ...

  2. 6.17考试总结(NOIP模拟8)[星际旅行·砍树·超级树·求和]

    6.17考试总结(NOIP模拟8) 背景 考得不咋样,有一个非常遗憾的地方:最后一题少取膜了,\(100pts->40pts\),改了这么多年的错还是头一回看见以下的情景... T1星际旅行 前 ...

  3. 5.23考试总结(NOIP模拟2)

    5.23考试总结(NOIP模拟2) 洛谷题单 看第一题第一眼,不好打呀;看第一题样例又一眼,诶,我直接一手小阶乘走人 然后就急忙去干T2T3了 后来考完一看,只有\(T1\)骗到了\(15pts\)[ ...

  4. 5.22考试总结(NOIP模拟1)

    5.22考试总结(NOIP模拟1) 改题记录 T1 序列 题解 暴力思路很好想,分数也很好想\(QAQ\) (反正我只拿了5pts) 正解的话: 先用欧拉筛把1-n的素数筛出来 void get_Pr ...

  5. [考试总结]noip模拟23

    因为考试过多,所以学校的博客就暂时咕掉了,放到家里来写 不过话说,vscode的markdown编辑器还是真的很好用 先把 \(noip\) 模拟 \(23\) 的总结写了吧.. 俗话说:" ...

  6. 2021.9.17考试总结[NOIP模拟55]

    有的考试表面上自称NOIP模拟,背地里却是绍兴一中NOI模拟 吓得我直接文件打错 T1 Skip 设状态$f_i$为最后一次选$i$在$i$时的最优解.有$f_i=max_{j<i}[f_j+a ...

  7. 6.10考试总结(NOIP模拟6)

    前言 就这题考的不咋样果然还挺难改的.. T1 辣鸡 前言 我做梦都没想到这题正解是模拟,打模拟赛的时候看错题面以为是\(n\times n\)的矩阵,喜提0pts. 解题思路 氢键的数量计算起来无非 ...

  8. NOIP 模拟 10 考试总结

    T1 一道很妙的题,打暴力分也很多,但是考试的时候忘开 long long 了. 题解 T2 一道挺水的题,不过...(打挂了) 题解 T3 此题甚妙,转化真多,不过对思维是一个非常大的扩展 题解 考 ...

  9. 2021.10.15考试总结[NOIP模拟77]

    \(n=40\)考虑\(meet \;in \;the \;middle\) 某个元素有关的量只有一个时考虑转化为树上问题 对暴力有自信,相信数据有梯度 没了 UPD:写了个略说人话的. T1 最大或 ...

随机推荐

  1. LeetCode 每日一题「判定字符是否唯一」

    我是陈皮,一个在互联网 Coding 的 ITer,微信搜索「陈皮的JavaLib」第一时间阅读最新文章,回复[资料],即可获得我精心整理的技术资料,电子书籍,一线大厂面试资料和优秀简历模板. 题目 ...

  2. 『动善时』JMeter基础 — 41、使用JMeter连接数据库(MySQL)

    目录 1.为什么要使用JMeter连接数据库 2.JMeter连接数据库的前提 3.JDBC连接配置组件界面介绍 4.JMeter连接数据库演示 (1)测试计划内包含的元件 (2)测试计划中添加链接数 ...

  3. 这 7 个 Linux 命令,你是怎么来使用的?

    使用 Linux 系统的开发者,很多人都有自己喜欢的系统命令,下面这个几个命令令是我平常用的比较多的,分享一下. 我不会教科书般的罗列每个指令的详细用法,只是把日常开发过程中的一些场景下,经常使用的命 ...

  4. 【NX二次开发】Block UI 指定坐标系

    属性说明 属性   类型   描述   常规           BlockID    String    控件ID    Enable    Logical    是否可操作    Group    ...

  5. 03:进程Queue --- 生产者消费者模型

    1 进程Queue介绍 1 进程间数据隔离,两个进程进行通信,借助于Queue​2 进程间通信:IPC -借助于Queue实现进程间通信    -借助于文件        -借助于数据库    -借助 ...

  6. SpringBoot代码与jar包分离部署

    第一步,打出带有jar包的SpringBoot工程 首先配置pom.xml文件 <build> <finalName>demo</finalName> <pl ...

  7. noip2012 总结

    Vigenère 密码 题目描述 16 世纪法国外交家 Blaise de Vigenère 设计了一种多表密码加密算法――Vigenère 密码.Vigenère 密码的加密解密算法简单易用,且破译 ...

  8. RobotFramework + Python 自动化入门 四 (Web进阶)

    在<RobotFramwork + Python 自动化入门 一>中,完成了一个Robot环境搭建及测试脚本的创建和执行. 在<RobotFramwork + Python 自动化入 ...

  9. Android集合中对象排序

    如果将集合中的对象进行排序,最近使用了一个简单的方法解决了,随笔记下来. 主要思路: 首先,新建类实现Comparator<?>,这个类是做比较的关键类,一般做比较的类型 int 或 St ...

  10. ESCMScript(1)let和const

    1.let命令 基本语法 ES6 新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效. { let a = 1 var b = 2 console ...