首页 > 其他分享 >CF1835C. Twin Clusters

CF1835C. Twin Clusters

时间:2023-06-19 09:22:05浏览次数:35  
标签:map int 区间 Twin CF1835C 随机 X2 Clusters Y2

题目大意

给出一个长为\(2^{K+1}\)的序列,每个元素在\([0,4^K)\)之间,
序列中找到两个不相交的区间使得二者的异或和相等

\(K<=17,\sum 2^{K+1}<=2^{18}\)

题解

好题,但最后没有break出去绝杀失败了,rk70=>rk150

因为元素大小是\(4^K\)级别的,和大小相关的算法(FWT)都没用了,所以不如直接随机

发现长度为\(2^{K+1}\)的序列里有\(2^K(2^{K+1}+1)\)个区间,即大于\(2*4^K\)个,那么这些区间的取值分配到\([0,4^K)\)平均每个位置有大于2个

考虑随机,发现如果按照异或值s随机,可以构造把区间集中到某些特定的s上,那样随机次数会变多(如果一个s只有<=1个区间显然选不出来),同时需要找两个区间

于是考虑直接随机一个区间[x,y],然后找另一个符合异或值s的区间:
直接把r从1=>y-1,用map找l;然后把l从n=>x+1,用map找r(\(n=2^{K+1}\))

这样找到的区间可能有交,但只要不完全包含就可以去掉交集使其合法


期望随机次数\(O(1)\),一次\(O(n\log)\),实际跑挺快

code

#include <bits/stdc++.h>
#define fo(a,b,c) for (a=b; a<=c; a++)
#define fd(a,b,c) for (a=b; a>=c; a--)
#define ll long long
#define file
using namespace std;

int T,K,n,i,j,k,l,x,y,X1,Y1,X2,Y2;
ll a[262254],sum;
bool Find;
map<ll,int> mp;
map<ll,int> :: iterator I;

int random(int x,int y)
{
	return (32768ll*rand()+rand())%(y-x+1)+x;
}

int main()
{
	srand(time(0));
//	freopen("C.in","r",stdin);
	
	scanf("%d",&T);
	for (;T;--T)
	{
		scanf("%d",&K);n=1<<(K+1);
		fo(i,1,n) scanf("%lld",&a[i]),a[i]^=a[i-1];
		
		Find=0;
		
		fo(l,1,100)
		{
			x=random(1,n);
			y=random(1,n);
			if (x>y) swap(x,y);
			
			sum=a[y]^a[x-1];
			
			mp.clear();
			fo(i,1,n)
			{
				if (i<x)
				mp[a[i-1]]=i;
				
				I=mp.find(sum^a[i]);
				if (I!=mp.end())
				{
					X1=I->second;
					Y1=i;
					X2=x;
					Y2=y;
					
					if (X2<=Y1)
					{
						swap(X2,Y1);
						--Y1;
						++X2;
						
					}
						if (X1<=Y1 && X2<=Y2)
						{
							Find=1;
							break;
						}
				}
			}
			
			if (Find==1) break; //就是这里没break
			
			if (x==2 && y==2)
			n=n;
			
			mp.clear();
			fd(i,n,x+1)
			{
				if (y<i)
				mp[a[i]]=i;
					
				I=mp.find(sum^a[i-1]);
				if (I!=mp.end())
				{
					X1=i;
					Y1=I->second;
					X2=x;
					Y2=y;
					swap(X1,X2);
					swap(Y1,Y2);
					
					if (X2<=Y1)
					{
						swap(X2,Y1);
						--Y1;
						++X2;
						
					}
						if (X1<=Y1 && X2<=Y2)
						{
							Find=1;
							break;
						}
				}
			}
			if (Find==1) break; //就是这里没break
		}
		
		if (!Find)
		printf("%d\n",-1);
		else
		printf("%d %d %d %d\n",X1,Y1,X2,Y2);
	}
}

标签:map,int,区间,Twin,CF1835C,随机,X2,Clusters,Y2
From: https://www.cnblogs.com/gmh77/p/17490274.html

相关文章

  • 1107 Social Clusters
    题目:Whenregisteronasocialnetwork,youarealwaysaskedtospecifyyourhobbiesinordertofindsomepotentialfriendswiththesamehobbies.A socialcluster isasetofpeoplewhohavesomeoftheirhobbiesincommon.Youaresupposedtofindallt......
  • Delphi SynCrtSock TWinHTTP
    TWinHTPP ///aclasstohandleHTTP/1.1requestusingtheWinHTTPAPI//-hasacommonbehaviorasTHttpClientSocket()butseemstobefaster//overanetworkandisabletoretrievethecurrentproxysettings//(ifavailable)andhandlesecurehttpscon......
  • SetWindowsHookEx - 设置钩子
    提示:如果要设置系统级钩子,钩子函数必须在DLL中.SetWindowsHookEx( idHook:Integer; {钩子类型} lpfn:TFNHookProc;{函数指针} hmod:HINST;   {包含钩子函数的模块(EXE、DLL)句柄;一般是HInstance;如果是当前线程这里可以是0} dwThreadId:DW......
  • MFC-SetWindowLong设置窗口样式、窗口标识符ID、处理函数
     修改样式LONGStyles;Styles=GetWindowLong(hWnd4,GWL_STYLE);//获取原窗口风格/*参数1:HWNDhWnd窗口句柄参数2:intnIndex改变窗口上的何种属性*/LONGl=SetWindowLong(hWnd4,GWL_STYLE,Styles|LVS_REPORT);//设置新的......
  • MFC-GetWindowLong获取窗口样式、窗口标识符ID、处理函数
     获取窗口样式LONGStyles=GetWindowLong(hWnd4,GWL_STYLE);//获取窗口风格/*参数1:HWNDhWnd窗口句柄参数2:intnIndex改变窗口上的何种属性窗口属性包括窗口的样式(GWL_STYLE)、扩展样式(GWL_EXSTYLE)、窗口函数、窗......
  • MFC-SetWindowPos改变窗口的尺寸,位置和Z序
     HWNDhWnd=::FindWindow(_T("Notepad"),NULL);//获取记事本窗口if(!hWnd){AfxMessageBox(_T("请打开记事本"));ExitProcess(0);}BOOLb=::SetWindowPos(hWnd,HWND_TOP,100,100,500,400,SWP_SHOWWINDOW);//改......
  • dxAlertWindowManager1 弹出提示窗口(09)
    默认显示效果(默认半透明,7秒后消失推出,鼠标移入后半透明效果消失)dxAlertWindowManager1.Show('提示','点击了表格'); 可以运行多次,自动垛叠显示01]添加图片显示拖一个cxImageList1,添加64*64图标dxAlertWindowManager1.Show('提示','点击了表格',0); ......
  • MFC-GetWindowRect获取指定窗口或控件的边框矩形的尺寸
     HWNDhDlgWnd=::FindWindow(_T("#32770"),_T("测试窗口"));if(hDlgWnd){::ShowWindow(hDlgWnd,SW_NORMAL);::SetForegroundWindow(hDlgWnd);HWNDhBtn=::GetDlgItem(hDlgWnd,0x3E8);CRectmRect;......
  • MFC-GetWindowThreadProcessId获取指定窗口线程ID和进程ID
     HWNDhWnd=::FindWindow(NULL,_T("sss.txt-记事本"));DWORDdwTID=0;DWORDdwPID=NULL;dwTID=::GetWindowThreadProcessId(hWnd,&dwPID......
  • 在TwinCat3上同时对两个从站发送数字量,验证EtherCat同步性
    提问: TwinCat3上面接了两个从站,都在正常工作中。我想做的是同时对两个从站发出数字量信息。比方说,我的从站1上面有LED0-LED7,都是由主站TwinCat控制亮灭。从站2也有LED0-L......