[构造训练]CF1227G Not Same,CF1375H Set Merging,CF1364E X-OR

文章目录

  • T1:CF1227G Not Same
    • solution
    • code
  • T2:CF1364E X-OR
    • solution
    • code
  • T3:CF1375H Set Merging
    • solution
    • code

~~脑子是个好东西,希望人人都有
在这里插入图片描述

构造真的不是个东西,看了一天视频,没有一道题会做~~

T1:CF1227G Not Same

点击查看

solution

通过观察样例输出,像01矩阵,事实证明,的确如此
将问题转化一下,变成矩阵思考
每一列的和一定,每一行互不相同

先考虑如果全是nnn,可以怎么构造??
——很简单
n×nn\times nn×n的全是111的矩阵,挖掉对角线,然后再填一行全是111

这个做法提供了正解方向
考虑能否构造出一个n+1n+1n+1nnn列的符合要求的矩阵??
——答案是当然可以

将所有数字从大到小排序,对于iii,就从第iii行开始填
一直往下填,如果不够就跳到第111行再继续填
在这里插入图片描述


简单证明一下,为什么这么填就保证了行行之间互不相同??——反证法

假设第iii行和第jjj行相同(i<j)(i<j)(i<j),用(i,j)(i,j)(i,j)表示第iii行第jjj

必有(i,j)=1,(j,i)=1(i,j)=1,(j,i)=1(i,j)=1,(j,i)=1
jjj行和第iii行的jjj列都为111,表明aj>1a_j>1aj>1

思考i+1i+1i+1列,有ai≥ai+1a_i\ge a_{i+1}aiai+1
因为所有数字取值[1,n][1,n][1,n],而我们构造的矩阵为n+1n+1n+1行,所以必有(i,i+1)=0(i,i+1)=0(i,i+1)=0
对应过去必有(j,i+1)=0(j,i+1)=0(j,i+1)=0

(i,i+1)=0(i,i+1)=0(i,i+1)=0这个条件能说明什么??
——ai>ai+1a_i>a_{i+1}ai>ai+1,即aia_iai一定严格大于ai+1a_{i+1}ai+1

再思考i+2i+2i+2列,有ai>ai+1≥ai+2,(i+1,i+2)=0a_i>a_{i+1}\ge a_{i+2},(i+1,i+2)=0ai>ai+1ai+2,(i+1,i+2)=0
可以画画图,发现如果想要(i,i+2)=1(i,i+2)=1(i,i+2)=1,必有ai=ai+1a_i=a_{i+1}ai=ai+1,矛盾
所以(i,i+2)=0(i,i+2)=0(i,i+2)=0,对应有(j,i+2)=0(j,i+2)=0(j,i+2)=0

(i+1,i+2)=0,(i,i+2)=0(i+1,i+2)=0,(i,i+2)=0(i+1,i+2)=0,(i,i+2)=0这个条件又能说明什么??
——ai>ai+1>ai+2a_i>a_{i+1}>a_{i+2}ai>ai+1>ai+2

以此类推,可以推出ai>ai+1>...>aj−1a_i>a_{i+1}>...>a_{j-1}ai>ai+1>...>aj1
(j,i+1)=0,(j,i+2)=0...(j,j−1)=0(j,i+1)=0,(j,i+2)=0...(j,j-1)=0(j,i+1)=0,(j,i+2)=0...(j,j1)=0
关注(j,j−1)=0(j,j-1)=0(j,j1)=0,翻译一下:第j−1j-1j1列的第jjj行为000
然而根据我们的规则,第j−1j-1j1列应当从j−1j-1j1行开始填
于是得到aj−1=1a_{j-1}=1aj1=1,又因为排序是从大到小,a∈[1,n]a∈[1,n]a[1,n],所以aj−1=aj=1a_{j-1}=a_j=1aj1=aj=1
与上面求出的aj>1a_j>1aj>1矛盾

故证明了构造的不重复性

在这里插入图片描述

在这里插入图片描述

code

#include <cstdio>
#include <algorithm>
using namespace std;
#define maxn 1005
int n, opt;
int a[maxn], id[maxn], pos[maxn];
int matrix[maxn][maxn];bool cmp( int i, int j ) {return a[i] > a[j];
}int main() {scanf( "%d", &n );for( int i = 1;i <= n;i ++ )scanf( "%d", &a[i] ), id[i] = i;sort( id + 1, id + n + 1, cmp );for( int i = 1;i <= n;i ++ )pos[id[i]] = i;for( int i = 1;i <= n;i ++ )for( int j = 1;j <= a[id[i]];j ++ ) {int p = ( i + j - 1 ) > n + 1 ? i + j - n - 2 : i + j - 1;matrix[p][i] = 1;}printf( "%d\n", n + 1 );for( int i = 1;i <= n + 1;i ++ ) {for( int j = 1;j <= n;j ++ )printf( "%d", matrix[i][pos[j]] );printf( "\n" );}return 0;
}

T2:CF1364E X-OR

点击查看

solution

首先要了解∣|操作原理,两个数的二进制上对应位置有一个为111,则∣|的结果便为111
故有两个很显然的结论

1.0∣x=x0|x=x0x=x
2.x∣y≥x,x∣y≥yx|y\ge x,x|y\ge yxyx,xyy

观察总操作次数比2n2n2n多了几次常数操作
于是乎,想到如何在nnn次查询左右找出000所在的位置
然后将其余位置依次与000询问,就能得到位置上的数值大小了

接下来就只说说如何找000??
——其实很简单
先随便选两个x,yx,yx,y,然后与剩下的数依次查询
1.Px∣Py>Py∣Pz⇒Px≠0,x=zP_x|P_y>P_y|P_z\Rightarrow P_x≠0,x=zPxPy>PyPzPx=0,x=z
2.Px∣Py<Py∣PzP_x|P_y<P_y|P_zPxPy<PyPz,此时不进行任何操作
3.Px∣Py=Py∣Pz⇒Py≠0,y=zP_x|P_y=P_y|P_z\Rightarrow P_y≠0,y=zPxPy=PyPzPy=0,y=z
这样就锁定了x,yx,yx,y中必有一个为000
再随机zzz,或PzP_zPz的值更小的,便是000
在这里插入图片描述

code

#include <cstdio>
#include <algorithm>
using namespace std;
#define maxn 5000
int n;
int s[maxn], ans[maxn];int ask( int x, int y ) {printf( "? %d %d\n", x, y );fflush( stdout );int z;scanf( "%d", &z );return z;
}int main() {scanf( "%d", &n );for( int i = 1;i <= n;i ++ )s[i] = i;random_shuffle( s + 1, s + n + 1 );int x = s[1], y = s[2];int val = ask( x, y ); for( int i = 3;i <= n;i ++ ) {int z = s[i];if( z == x || z == y ) continue;else {int w = ask( z, y );if( w < val ) val = w, x = z; else if( w == val ) y = z, val = ask( x, y);}}while( 1 ) {int z = s[rand() % n + 1];if( z == x || z == y ) continue;else {int v1 = ask( x, z );int v2 = ask( y, z );if( v1 == v2 ) continue;/*不能删去!!可能出现x,y其中一个为0另外一个又恰好是z的子串(其二进制上为1的每一位,z对应的也是1)此时或起来的值都是z无法判断谁是0 */ if( v1 > v2 ) swap( x, y );break;}}for( int i = 1;i <= n;i ++ )if( i == x ) continue;else ans[i] = ask( i, x );printf( "!" );for( int i = 1;i <= n;i ++ )printf( " %d", ans[i] );return 0;
} 
/*
P(x)|P(y)>P(y)|P(z) ——> P(x)≠0 z代替x 
P(x)|P(y)<P(y)|P(z) 不操作
P(x)|P(y)=P(y)|P(z) ——> P(y)≠0 z代替y
最后随机一个z来判断x,y谁是0 
*/

T3:CF1375H Set Merging

点击查看

solution

先从最原始的暴力下手,即找到[l,r][l,r][l,r]里的每一个数,然后依次合并起来即可
——这当然不是正解,但告诉我们单次查询的操作次数上限为nnn
优化暴力
考虑构建权值线段树,每个节点存储节点区间[l,r][l,r][l,r]中每个值出现的位置,再从小到大排序
线段树上每个节点最多有n2n^2n2种不同本质的查询(即查询的l,rl,rl,r不同)
可以套一个mapmapmap来记录(记忆化),存在即出现过,即有现成的集合使用
在这里插入图片描述

时间复杂度分析详见第一篇

code

#include <map>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
#define maxn 100005
#define maxq 2200005
#define Pair pair < int, int >
struct node {vector < int > num;map < Pair, int > Hash;
}t[maxn << 2];
Pair vis[maxq];
int n, Q, cnt;
int a[maxn], pos[maxn], ans[maxn];void build( int now, int l, int r ) {for( int i = l;i <= r;i ++ )t[now].num.push_back( pos[i] );sort( t[now].num.begin(), t[now].num.end() );if( l == r ) return;int mid = ( l + r ) >> 1;build( now << 1, l, mid ), build( now << 1 | 1, mid + 1, r );
}int query( int now, int l, int r ) {int left = lower_bound( t[now].num.begin(), t[now].num.end(), l ) - t[now].num.begin();int right = upper_bound( t[now].num.begin(), t[now].num.end(), r ) - t[now].num.begin() - 1;if( right < left ) return 0;if( left == right ) return t[now].num[left];int pos = t[now].Hash[make_pair( left, right )];if( pos ) return pos;int lson = query( now << 1, l, r ), rson = query( now << 1 | 1, l, r );if( ! lson || ! rson ) return t[now].Hash[make_pair( left, right )] = lson | rson;vis[++ cnt] = make_pair( lson, rson );return t[now].Hash[make_pair( left, right )] = cnt;
}int main() {scanf( "%d %d", &n, &Q );cnt = n;for( int i = 1;i <= n;i ++ )scanf( "%d", &a[i] ), pos[a[i]] = i;	build( 1, 1, n );for( int i = 1, l, r;i <= Q;i ++ ) {scanf( "%d %d", &l, &r );ans[i] = query( 1, l, r );}printf( "%d\n", cnt );for( int i = n + 1;i <= cnt;i ++ )printf( "%d %d\n", vis[i].first, vis[i].second );for( int i = 1;i <= Q;i ++ )printf( "%d ", ans[i] );return 0;
} 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317739.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

asp.net core 环境(Development、Staging 、Production)

一.在asp.net core中使用多个环境ASP.NET Core 配置是基于运行时环境, 使用环境变量。ASP.NET Core 在应用启动时读取环境变量ASPNETCORE_ENVIRONMENT&#xff0c;并将该值存储在 IHostingEnvironment.EnvironmentName 中。ASPNETCORE_ENVIRONMENT 可设置为任意值&#xff0c;但…

ASP.NET Core 2.1 : 图解路由(2.1 or earler)

本文通过一张图来看一下路由的配置以及请求处理的机制。 一、概述路由主要有两个主要功能&#xff1a;将请求的URL与已定义的路由进行匹配&#xff0c;找到该URL对应的处理程序并传入该请求进行处理。根据已定义的路由生成URL这两个功能看起来这两个是相反的。A.路由的配置路由…

[数据结构专训][GXOI/GZOI2019]旧词,[hdu5118]GRE Words Once More!,[hdu6333]Problem B. Harvest of Apples

文章目录T1&#xff1a;[GXOI/GZOI2019]旧词solutioncodeT2&#xff1a;GRE Words Once More!solutioncodeT3&#xff1a;Problem B. Harvest of ApplessolutioncodeT1&#xff1a;[GXOI/GZOI2019]旧词 点击查看 solution 考虑k1k1k1的情况 由于dep[lca(x,y)]∣{z,zdep[lca(…

浅谈c#垃圾回收机制(GC)

写了一个window服务&#xff0c;循环更新sqlite记录&#xff0c;内存一点点稳步增长。三天后&#xff0c;内存溢出。于是&#xff0c;我从自己的代码入手&#xff0c;查找到底哪儿占用内存释放不掉&#xff0c;最终明确是调用servicestack.ormlite更新sqlite数据库造成的。至于…

洛谷P2497:基站建设(splay、斜率优化)

所谓splay斜率优化dp&#xff0c;就是利用splay和斜率对dp进行优化 &#xff08;逃&#xff09; 解析 在斜优的时候&#xff0c;有时我们会发现我们插入的点的横坐标并不单调 这个时候我们就无法利用单调队列维护凸包了 这时&#xff0c;我们就要请出今天的主角&#xff1a;s…

MediatR 知多少

引言首先不用查字典了&#xff0c;词典查无此词。猜测是作者笔误将Mediator写成MediatR了。废话少说&#xff0c;转入正题。先来简单了解下这个开源项目MediatR&#xff08;作者Jimmy Bogard&#xff0c;也是开源项目AutoMapper的创建者&#xff0c;在此表示膜拜&#xff09;&a…

网络分析(带权并查集)

网络分析 题意&#xff1a; 有n个节点&#xff0c;一开始彼此独立&#xff0c;有两个操作&#xff0c;第一个操作时是连接两个节点&#xff0c;第二个操作是对一个节点x&#xff0c;&#xff08;在进行第二个操作时&#xff0c;与该点相连的点也会x&#xff09; 问每个节点的…

良心发现,时隔一年再回首莫比乌斯反演(公式性质证明+题目练习)

文章目录莫比乌斯反演引入公式性质模板公式证明莫比乌斯函数前缀和题目练习完全平方数[HAOI2011]ProblembYY的GCD[SDOI2014]数表[国家集训队]Crash的数字表格/JZPTAB[SDOI2015]约数个数和寒假疫情期间跟着lmm学了一遍&#xff0c;完全是懵逼到底状态&#xff0c;以至于后面考到…

平面切分

平面切分 问题描述 题解&#xff1a; 我对这种题极其非常不擅长。。。 另外吐槽为什么acwing的数据卡的这么死&#xff0c;蓝桥杯官网数据那么水 其实题目很简单&#xff0c;如果只有一个直线&#xff0c;那么就是两部分&#xff0c;如果是两个直线&#xff0c;这两个直线不相…

新起点!新征程!微软技术俱乐部(苏州)成立大会暨微软技术交流会

2019年1月19日&#xff0c;苏州微软将举办苏州史上最盛大的开发者聚会&#xff0c;微软技术俱乐部成立大会暨微软技术交流会。超越苹果&#xff0c;登顶世界市值第一&#xff01;云与AI两大技术支柱支撑起的微软帝国&#xff0c;正向万亿美元俱乐部挺进&#xff01;微软的改变我…

跨平台、跨语言应用开发工具,Elements 介绍

目录1&#xff0c;Elements 介绍2&#xff0c;Elements 版本3&#xff0c;Elements 能干嘛4&#xff0c;Elements IDES5&#xff0c;Elements 工具1&#xff0c;Elements 介绍RemObjects Elements&#xff0c;是多平台移动项目开发工具&#xff0c;是一款可以帮助开发人员在 不…

后缀自动机(SAM)构造实现过程演示+习题集锦

文章目录后缀自动机算法实现过程模板习题洛谷后缀自动机模板题品酒大会[HEOI2015]最短不公共子串字符串蒟蒻写这篇blogblogblog主要是存一下&#xff0c;后缀自动机的详细搭建过程&#xff0c;方便以后复习 具体的某些证明&#xff0c;为什么这么做&#xff0c;正确性劈里啪啦一…

使用logdashboard进行可视化的日志追踪

本文源码在Github可以找到下载LogDashboard如果你还不了解LogDashboard请看这里。 LogDashboard 1.1版本支持请求追踪,虽然目前版本还没有发布。不过这个功能可以先睹为快效果图下载项目首先我们可以在 https://github.com/liangshiw/LogDashboard/tree/master/samples/Request…

ML.NET 0.9特性简介

ML.NET 0.9已于上周发布&#xff0c;距离上次0.8版本的发布只有一个多月&#xff0c;此次增加的新特性主要包括特征贡献计算&#xff0c;模型可解释性增强&#xff0c;ONNX转换对GPU的支持&#xff0c;Visual Studio ML.NET项目模板预览&#xff0c;以及API改进。特征贡献计算特…

[学习笔记] 初次见面,请多关照 (公式推导+题集)——杜教筛

筛积性函数的前缀和常见积性函数公式推导狄利克雷卷积杜教筛实现常见卷积习题集Sum神犇和蒟蒻简单的数学题常见积性函数 μ\muμφφφd(n)d(n)d(n)&#xff1a;nnn的约数个数σ(n)σ(n)σ(n)&#xff1a;nnn的约数和ϵ(n)ϵ(n)ϵ(n)&#xff1a;单位元函数&#xff0c;e(n)[n1…

AOP 还在配置吗改用打标签模式吧!

为什么我喜欢打标签来配置AOP1. 配置多很混乱&#xff0c;代码里面很难分辨出来哪些是AOP容器(比如属性注入)2. 对于代码生成器生成的代码里面还需要手动加到配置里面3. 连java spring现在都是清一色的注解来代替xml&#xff0c;这个就是趋势所在我基于Autofac开发了一个基于标…

DZY Loves Math IV(杜教筛)

文章目录titlesolutioncodetitle solution 这道题是多么的妙啊&#xff0c;完全不是我能推出来的式子呢&#xff01; 观察数据范围&#xff0c;有点奇怪欸&#xff0c;在暗示我&#xff1f;&#xff1f; 考虑暴力枚举nnn S(n,m)∑i1mφ(ni)S(n,m)\sum_{i1}^mφ(n\times i)S…

codeforces:CF1604 总结

前言 solve&#xff1a;4 rank&#xff1a;48&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 这排名我不理解了 solve4真真不算多啊… 而且前四题感觉也不算太难… 仔细看了看榜 哦… 因为这次…

IdentityServer4直播

大家好&#xff0c;很久没有更新公众号&#xff0c;让各位久等了&#xff0c;主要是最近出除了工作之外&#xff0c;一直私下在学习和研究IdentityServer4&#xff0c;后续会腾出一部分时间陆续更新公众号。对于IdentityServer4(简称IDS)&#xff0c;网上的资料少之可怜&#x…

.NET Core 3.0:System.Data的变化

System.Data虽然不引人关注&#xff0c;但在.NET中&#xff0c;System.Data对于各种关系数据库的连接是非常重要的。System.Data也被称为ADO.NET&#xff0c;其前身是ActiveX Data Objects。System.Data提供了通过的框架&#xff0c;在她的基础上.NET数据驱动应用可以被构建。这…