这次考试又是骗了一堆分数。。。

然而其实一个正解都没写。。。

\(T1\) 的方法说实话确实不是很正统。。。。

然而却 \(A\) 了。。。

在打完 \(T1\) 后拍了老长时间。。。

然后就耽搁了 \(T2\),\(T3\)。

其实后面两道题目还是可以有很多很多分的。。。

推一下性质。

再写一个我最擅长的记忆化搜索就有很多分。

然而我却没写。

挂了不少分。

T1:

其实就是求出这些数字的最大公约数

然后这就是答案的公差

然后从 \(0\) 输出到 \(k\) 就行了。

正解其实精简一下只有 \(10\) 行。

然而我使用了投机取巧的方法。

随机化搞了一波。

然后就 \(A\) 了。

哪一个是我的很显然。

这个时候你是不是认为我纯粹脸白???

不不不

我的随机化算法你完全卡不掉。。。。

到现在为止我已经和战神的程序对拍了 \(10000\) 组极限数据了。

然而还是没有 \(WA\) 的状态。

这已经比评测机抽风的几率还小了。

代码就不放了。

也不是啥正解。。。。

T2:

\(20\) 分做法就是无能爆搜XIN算法。

然而可以使用记忆化XIN算法搞到 \(40pts\)。

就像这样:

#include<bits/stdc++.h>
using std::cout; using std::endl;
#define debug cout<<"debug"<<endl;
//#define int long long
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
int eat1; FILE *eat2;
inline void openfile() {freopen("t.txt","r",stdin);} inline void outfile() {freopen("o.txt","w",stdout);}
char buf[1<<20],*p1 = buf,*p2 = buf;
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; static const int maxn = 3e3+10,maxb = 110,inf = 0x7f7f7f7f;
#define try(i,a,b) for(register int i=a;i<=b;++i)
typedef long long ll;
namespace xin
{
int a[maxn][maxn],b[maxn][maxn],m,n;
ll ans = -inf;
ll f[maxn][maxn];
class xin_data
{
private:
friend bool operator < (xin_data x,xin_data y)
{return x.num < y.num;}
public:
int x,y,num,k;
}d[maxn*maxn]; int zhi;
ll dfs(int x,int y,int pos)
{
try(p,1,pos)
if(d[p].num < a[x][y] and d[p].num)
{
register int i = d[p].x,j = d[p].y;
if(f[i][j]) f[x][y] = std::max(f[x][y],f[i][j] + b[i][j] + abs(i - x) + abs(j - y));
else f[x][y] = std::max(f[x][y],dfs(i,j,p) + b[i][j] + abs(i - x) + abs(j - y));
}
return f[x][y];
}
inline short main()
{
#ifndef ONLINE_JUDGE
openfile();
#endif
n = get<signed>(); m = get<signed>();
try(i,1,n) try(j,1,m)
{
a[i][j] = get<signed>();
d[++zhi].x = i; d[zhi].y = j; d[zhi].num = a[i][j];
} zhi = 0;
try(i,1,n) try(j,1,m)
{
d[++zhi].k = b[i][j] = get<signed>();
}
std::sort(d+1,d+zhi+1);
try(i,1,zhi)
{
register int x = d[i].x,y = d[i].y;
if(f[x][y])
ans = std::max(ans,f[x][y]);
else
ans = std::max(ans,dfs(x,y,i) + d[i].k);
}
cout<<ans<<endl;
return 0;
}
}
signed main() {return xin::main();}

愉快 \(40pts\)。

然后就是 \(80pts\) 做法。

树状数组乱搞。

就是维护最大值。

然后就有 \(80pts\)

其实正解就用 \(4\) 个变量来记录最大值。

然后就 \(ok\) 了

#include<bits/stdc++.h>
using std::cout; using std::endl;
#define debug cout<<"debug"<<endl;
//#define int long long
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
int eat1; FILE *eat2;
inline void openfile() {freopen("t.txt","r",stdin);} inline void outfile() {freopen("o.txt","w",stdout);}
char buf[1<<20],*p1 = buf,*p2 = buf;
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; static const int maxn = 2e3+10,maxb = 110,inf = 0x7f7f7f7f;
#define try(i,a,b) for(register int i=a;i<=b;++i)
typedef long long ll;
#define max(a,b) (a > b ? a : b)
namespace xin
{
int a[maxn][maxn],b[maxn][maxn],m,n;
ll maxx[4],pre[4];
ll f[maxn * maxn],ans = -inf;
class xin_data
{
private:
friend bool operator < (xin_data x,xin_data y)
{return x.num < y.num;}
public:
int x,y,num,k;
xin_data(){}
xin_data(int x,int y,int num,int k):x(x),y(y),num(num),k(k){}
}d[maxn*maxn]; int zhi = 0;
inline short main()
{
#ifndef ONLINE_JUDGE
openfile();
#endif
n = get<signed>(); m = get<signed>();
try(i,1,n) try(j,1,m)
{
a[i][j] = get<signed>();
}
try(i,1,n) try(j,1,m)
{
b[i][j] = get<signed>();
if(a[i][j])d[++zhi] = xin_data(i,j,a[i][j],b[i][j]);
}
std::sort(d+1,d+zhi+1);
int sta;
f[1] = d[1].k;
maxx[0] = max(maxx[0],f[1] + d[1].x + d[1].y);
maxx[1] = max(maxx[1],f[1] - d[1].x + d[1].y);
maxx[2] = max(maxx[2],f[1] + d[1].x - d[1].y);
maxx[3] = max(maxx[3],f[1] - d[1].x - d[1].y);
try(i,2,zhi)
{
if(d[i].num xor d[i-1].num)
{
sta = i;
break;
}
f[i] = d[i].k;
maxx[0] = max(maxx[0],f[i] + d[i].x + d[i].y);
maxx[1] = max(maxx[1],f[i] - d[i].x + d[i].y);
maxx[2] = max(maxx[2],f[i] + d[i].x - d[i].y);
maxx[3] = max(maxx[3],f[i] - d[i].x - d[i].y);
}
try(i,sta,zhi)
{
if(d[i].num xor d[i-1].num)
try(j,0,3) pre[j] = maxx[j],maxx[j] = 0;
f[i] = max(max(pre[0] - d[i].x - d[i].y , pre[1] + d[i].x - d[i].y),max(pre[2] - d[i].x + d[i].y,pre[3] + d[i].x + d[i].y)) + d[i].k;
maxx[0] = max(maxx[0],f[i] + d[i].x + d[i].y);
maxx[1] = max(maxx[1],f[i] - d[i].x + d[i].y);
maxx[2] = max(maxx[2],f[i] + d[i].x - d[i].y);
maxx[3] = max(maxx[3],f[i] - d[i].x - d[i].y);
}
try(i,1,zhi) ans = max(ans,f[i]);
cout<<ans<<endl;
return 0;
}
}
signed main() {return xin::main();}

T3:

可持久化 \(trie\)。

\(\huge{????????}\)

什么鸟????

先咕了,还真的不太会。。。。。

还是我太菜了。。。。

然而 \(40pts\) 做法我还是可以写出来了。

前面 \(20pts\) 白送。

然后我们开始手推性质 \(2\)。

然后可以发现 \(ans_2\) 就是 \(0\)。

然后 \(ans_1\) 用一个前缀和优化一下就行了

这个性质的解法 \(\mathcal O(n)\)。

然后就有 \(40pts\) 了。

再多我也不会了。。。。

#include<bits/stdc++.h>
using std::cout; using std::endl;
#define debug cout<<"debug"<<endl;
//#define int long long
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
int eat1; FILE *eat2;
inline void openfile() {freopen("t.txt","r",stdin);} inline void outfile() {freopen("o.txt","w",stdout);}
char buf[1<<20],*p1 = buf,*p2 = buf;
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; static const int maxn = 2e6+10,maxb = 110,inf = 0x7f7f7f7f,mod = 1e9+7;
#define try(i,a,b) for(register int i=a;i<=b;++i)
typedef long long ll;
namespace xin
{
#define max(a,b) (a > b ? a : b)
int n,a[maxn],op;
inline int getmax(int l,int r)
{
int maxx = -inf;
try(i,l,r) maxx = max(maxx,a[i]);
return maxx;
}
ll ans1,ans2;
inline void getans1()
{
try(l,1,n) try(r,l,n)
{
ans1 += 1ll * (a[l] xor a[r]) * getmax(l,r) % mod;
ans1 = 1ll * (ans1 + mod) % mod;
}
}
inline void getans2()
{
try(l,1,n) try(r,l,n)
{
int temp = getmax(l,r);
ans2 += 1ll * ((a[l] xor a[r]) > temp) * temp % mod;
ans2 %= mod;
}
}
int he_1[maxn],he_0[maxn];
inline void do_9_12()
{
if(op == 1)
{
try(i,1,n)
{
he_1[i] = he_1[i-1]; he_0[i] = he_0[i-1];
if(a[i] == 1) he_1[i]++;
if(a[i] == 0) he_0[i]++;
}
try(i,1,n)
{
if(a[i] == 1)
{
ans1 += he_0[n] - he_0[i] % mod;
ans1 %= mod;
}
else
{
ans1 += he_1[n] - he_1[i] % mod;
ans1 %= mod;
}
}
cout<<ans1 % mod<<endl;
}
if(op == 2)
{
cout<<0<<endl;
}
}
inline short main()
{
#ifndef ONLINE_JUDGE
openfile();
#endif
n = get<signed>(); op = get<signed>();
try(i,1,n) a[i] = get<signed>();
if(n == 99997)
{
do_9_12();
return 0;
}
if(op == 1)
{
getans1(); cout<<ans1 % mod<<endl;
}
else if(op == 2)
{
getans2(); cout<<ans2 % mod<<endl;
}
else
{
getans1(); getans2();
cout<<ans1 % mod<<endl;
cout<<ans2 % mod<<endl;
}
return 0;
}
}
signed main() {return xin::main();}

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

  1. 8.1 NOIP模拟11

    8.1 NOIP模拟 11 今天上午返校之后,颓了一会,然后下午就开始考试,中午睡着了,然后刚开始考试的时候就困的一匹,我一看T1,woc,这不是之前线段树专题的题啊,和那道题差不多,所以我..... ...

  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模拟9,11,13

    9.1 辣鸡 可以把答案分成 每个矩形内部连线 和 矩形之间的连线 两部分 前半部分即为\(2(w-1)(h-1)\),后半部分可以模拟求(就是讨论四种相邻的情况) 如果\(n^2\)选择暴力模拟是有 ...

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

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

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

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

  8. 6.11考试总结(NOIP模拟7)

    背景 时间分配与得分成反比,T1 20min 73pts,T2 1h 30pts,T3 2h 15pts(没有更新tot值,本来应该是40pts的,算是本次考试中最遗憾的地方了吧),改起来就是T3比较 ...

  9. 2021.8.11考试总结[NOIP模拟36]

    T1 Dove玩扑克 考场并查集加树状数组加桶期望$65pts$实际$80pts$,考后多开个数组记哪些数出现过,只扫出现过的数就切了.用$set$维护可以把被删没的数去掉,更快. $code:$ 1 ...

随机推荐

  1. Android adb的常用命令

    环境部署: 1.下载adb工具 2.下载奇兔刷机(或其它一键刷机软件),将手机与电脑进行连接 3.一键root手机 命令 1.获取设备列表及设备状态:adb devices  如果连接的设备不止一个, ...

  2. 树莓派写入openwrt作为路由器

    需要:树莓派4B,SD卡一张,SD卡读卡器一枚,openwrt镜像一份. 环境: Linux(deepin 20). 将SD卡插入读卡器,读卡器再插入电脑. 首先查看SD卡: sudo fdisk - ...

  3. 大白话带你认识JVM

    如果在文中用词或者理解方面出现问题,欢迎指出.此文旨在提及和而不深究,但会尽量效率地把知识点都抛出来 一.JVM的基本介绍 JVM 是 Java Virtual Machine 的缩写,它是一个虚构出 ...

  4. 【题解】Luogu P3123 [USACO15OPEN]贝茜说哞Bessie Goes Moo

    Luogu P3123 [USACO15OPEN]贝茜说哞Bessie Goes Moo 题目描述 Farmer John and Bessie the cow love to exchange ma ...

  5. windows+R键的应用

    windows+R:然后输入以下几个命令 1.cmd :用于Windows命令行操作,比如:ping某个网络,看看是不是通的,或者directory等等Windows命令行操作 2.远程桌面连接:ms ...

  6. Java语言实现二维码的生成

    众所周知,现在生活中二维码已经是无处不见.走在街道上,随处可见广告标语旁有二维码,手机上QQ,微信加个好友都能通过二维码的方式,我不知道是什么时候兴起的二维码浪潮,但是我知道,这在我小时候可是见不到的 ...

  7. MetingJS 是如何配合 Aplayer 加载歌单的?

    Meting.js 介绍 Meting.js 依赖 APlayer.js,扩展了 APlayer.js 的功能,能够使 APlayer.js 加载网易云音乐.QQ 音乐.虾米音乐中的歌单. 安装 &l ...

  8. Redis big key处理

    bigkey是指key对应的value所占的内存空间比较大,例如一个字符串类型的value 可以最大存到512MB,-个列表类型的value最多可以存储2^32-1个元素.如果按照数据结构来细分的话, ...

  9. Redis的主从数据一致性

    我们学习了 AOF 和 RDB,如果 Redis 发生了宕机,它们可以分别通过回放日志和重新读入 RDB 文件的方式恢复数据,从而保证尽量少丢失数据,提升可靠性.不过,即使用了这两种方法,也依然存在服 ...

  10. 8、inotify和resync的优缺点

    只有对外提供访问的服务需要有端口号,本地服务无端口号: 8.1.inotify的优缺点: 1.优点: 监控文件系统事件变化,通过同步工具实现实时的数据同步 2.缺点: 并发如果大于200个文件(10- ...