当前位置: 首页 > news >正文

城市建设杂志社网站宁德市人社局官网

城市建设杂志社网站,宁德市人社局官网,设计师个人网站架构,石河子做网站公司交题:https://cms.ioi-jp.org/documentation A 给一个序列 a1,⋯,ana_1,\cdots,a_na1​,⋯,an​。 执行nnn个操作,第iii个操作为找出第iii个数前离其最近且与它相同的数的位置,把这两个数之间的数全部赋值aia_iai​。求最后的序列。 考虑第…

交题:https://cms.ioi-jp.org/documentation

A

给一个序列 a1,⋯,ana_1,\cdots,a_na1,,an
执行nnn个操作,第iii个操作为找出第iii个数前离其最近且与它相同的数的位置,把这两个数之间的数全部赋值aia_iai。求最后的序列。

考虑第iii个操作执行完后,iii之前每个数一定是连续出现正好一段或不出现。

#include<bits/stdc++.h> 
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForkD(i,k,n) for(int i=n;i>=k;i--)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Forpiter(x) for(int &p=iter[x];p;p=next[p])  
#define Lson (o<<1)
#define Rson ((o<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,0x3f,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define MEMx(a,b) memset(a,b,sizeof(a));
#define INF (0x3f3f3f3f)
#define F (1000000007)
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define vi vector<int> 
#define pi pair<int,int>
#define SI(a) ((a).size())
#define Pr(kcase,ans) printf("Case #%d: %lld\n",kcase,ans);
#define PRi(a,n) For(i,n-1) cout<<a[i]<<' '; cout<<a[n]<<endl;
#define PRi2D(a,n,m) For(i,n) { \For(j,m-1) cout<<a[i][j]<<' ';\cout<<a[i][m]<<endl; \} 
#pragma comment(linker, "/STACK:102400000,102400000")
#define ALL(x) (x).begin(),(x).end()
#define gmax(a,b) a=max(a,b);
#define gmin(a,b) a=min(a,b);
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{int x=0,f=1; char ch=getchar();while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}return x*f;
} 
int a[201000];
map<int,pair<int,int> > h;
int main()
{
//	freopen("A.in","r",stdin);
//	freopen(".out","w",stdout);int n=read();For(i,n) a[i]=read();	stack <pair<pair<int,int> , int > > st;For(i,n) {if(st.empty() || !h.count(a[i]) || h[a[i]] ==mp(0,0) ) {st.push(mp(mp(i,i),a[i]));h[a[i]]=mp(i,i);}else {while(!st.empty()) {auto p=st.top();st.pop();if(p.se==a[i]) {h[p.se]=mp(p.fi.fi,i);st.push(mp(h[p.se],a[i]));break;}else {h[p.se]=mp(0,0);}}}}while(!st.empty()) {auto p=st.top();st.pop();Fork(i,p.fi.fi,p.fi.se) a[i]=p.se;}For(i,n) cout<<a[i]<<endl;return 0;
}

B

nnn个点对,每个点对(x,y)(x,y)(x,y)可以覆盖S=(a,b)∣b<=y,∣a−x∣<=y−bS={(a,b)|b<=y,|a-x|<=y-b}S=(a,b)b<=y,ax<=yb。问取多少个点对能覆盖所有点对。

经典题

#include<bits/stdc++.h> 
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForkD(i,k,n) for(int i=n;i>=k;i--)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Forpiter(x) for(int &p=iter[x];p;p=next[p])  
#define Lson (o<<1)
#define Rson ((o<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,0x3f,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define MEMx(a,b) memset(a,b,sizeof(a));
#define INF (0x3f3f3f3f)
#define F (1000000007)
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define vi vector<int> 
#define pi pair<int,int>
#define SI(a) ((a).size())
#define Pr(kcase,ans) printf("Case #%d: %lld\n",kcase,ans);
#define PRi(a,n) For(i,n-1) cout<<a[i]<<' '; cout<<a[n]<<endl;
#define PRi2D(a,n,m) For(i,n) { \For(j,m-1) cout<<a[i][j]<<' ';\cout<<a[i][m]<<endl; \} 
#pragma comment(linker, "/STACK:102400000,102400000")
#define ALL(x) (x).begin(),(x).end()
#define gmax(a,b) a=max(a,b);
#define gmin(a,b) a=min(a,b);
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{int x=0,f=1; char ch=getchar();while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}return x*f;
} 
int n;
vector<pair<int,int> > v;
int main()
{
//	freopen("B.in","r",stdin);
//	freopen(".out","w",stdout);int n=read();For(i,n) {int a=read(),b=read();v.pb(mp(b-a,a+b));}sort(ALL(v));stack<pair<int,int> > st;	for(int i=0;i<n;i++) {auto now=v[i];while(!st.empty()){auto t=st.top();if(t.fi<=now.fi && t.se <=now.se) {st.pop(); }else break;}st.push(now);}cout<<SI(st)<<endl;return 0;
}

C

考虑n*n的四连通矩阵,每次可以上下左右走一个。
格子上有颜色(黑、白),且只有白色能走。现在你希望令2个白色格子连通。一次操作为把n∗nn*nnn的矩阵赋值为白色。问至少几次操作实现目标。

#include<bits/stdc++.h> 
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForkD(i,k,n) for(int i=n;i>=k;i--)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Forpiter(x) for(int &p=iter[x];p;p=next[p])  
#define Lson (o<<1)
#define Rson ((o<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,0x3f,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define MEMx(a,b) memset(a,b,sizeof(a));
#define INF (0x3f3f3f3f)
#define F (1000000007)
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define vi vector<int> 
#define pi pair<int,int>
#define SI(a) ((a).size())
#define Pr(kcase,ans) printf("Case #%d: %lld\n",kcase,ans);
#define PRi(a,n) For(i,n-1) cout<<a[i]<<' '; cout<<a[n]<<endl;
#define PRi2D(a,n,m) For(i,n) { \For(j,m-1) cout<<a[i][j]<<' ';\cout<<a[i][m]<<endl; \} 
#pragma comment(linker, "/STACK:102400000,102400000")
#define ALL(x) (x).begin(),(x).end()
#define gmax(a,b) a=max(a,b);
#define gmin(a,b) a=min(a,b);
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{int x=0,f=1; char ch=getchar();while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}return x*f;
} 
int r,c,n,sx,sy,tx,ty;
int dir[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
bool inside(int x,int y) {return 1<=x && x<=r &&1<=y &&y<=c;
}
vector<string> a;
bool state(int x,int y){return a[x-1][y-1]=='#';
}
pair<int,int> dis[6000000+10];
int id(int x,int y) {return c*(x-1)+y;
}
void pri(pair<int,int> p) {printf("(%d,%d)",p.fi,p.se);
}
void pri(vector<pair<int,int> > v) {for(auto a:v) {pri(a);cout<<":";int x=a.fi,y=a.se;pri(dis[id(x,y)]);cout<<" ";}cout<<endl;
}
void bfs() {vector<pair<int,int> > q0,qa,qb;int nowdis=0;For(i,r*c) dis[i]=mp(INF,INF);dis[id(sx,sy)]=mp(0,n);q0.pb(mp(sx,sy));while(SI(q0)) {int nxdis=nowdis+1;// relax q0for(int i=0;i<SI(q0);i++) {auto t=q0[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];Rep(di,4) {int nx=x+dir[di][0],ny=y+dir[di][1];if(!inside(nx,ny)) continue;if(dis[id(nx,ny)]!=mp(INF,INF)) continue;int sta=state(nx,ny);if(sta==0) { //whitedis[id(nx,ny)] = now_dis;q0.pb(mp(nx,ny));}}}	// q0 -> qaRep(i,SI(q0)) {qa.pb(q0[i]);}Rep(i,SI(qa)) {auto t=qa[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];Rep(di,2) {int nx=x+dir[di][0],ny=y+dir[di][1];if(!inside(nx,ny)) continue;if(dis[id(nx,ny)]!=mp(INF,INF)) continue;int sta=state(nx,ny);if(now_dis.fi==nowdis) {dis[id(nx,ny)] = mp(nxdis,1);}else if(now_dis.se+1<=n){dis[id(nx,ny)] = mp(nxdis,now_dis.se+1);}else continue;qa.pb(mp(nx,ny));}}//qa -> abRep(i,SI(qa)) {qb.pb(qa[i]);}Rep(i,SI(qb)) {auto t=qb[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];Fork(di,2,3) {int nx=x+dir[di][0],ny=y+dir[di][1];if(!inside(nx,ny)) continue;if(dis[id(nx,ny)]!=mp(INF,INF)) continue;int sta=state(nx,ny);if(now_dis.fi==nowdis) {dis[id(nx,ny)]=mp(nxdis,n+1);}else if(now_dis.fi==nxdis && now_dis.se<n &&  n+1<=2*n ) {dis[id(nx,ny)]=mp(nxdis,n+1);}else if(now_dis.fi==nxdis && now_dis.se==n && n+2<=2*n ) {dis[id(nx,ny)]=mp(nxdis,n+2);}else if(now_dis.fi==nxdis && now_dis.se>n && now_dis.se+1<=2*n ) {dis[id(nx,ny)]=mp(nxdis,now_dis.se+1);}else continue;qb.pb(mp(nx,ny));}}
//		
//		cout<<nowdis<<endl;
//		cout<<"q0"<<endl;
//		pri(q0);
//		cout<<"qa"<<endl;
//		pri(qa);
//		cout<<"qb"<<endl;
//		pri(qb);
//		//ab -> qc(q0)q0.resize(0);for(int i=0;i<qb.size();i++) {auto t=qb[i];int x=t.fi,y=t.se;auto now_dis=dis[id(x,y)];if(now_dis.fi==nxdis)q0.pb(qb[i]);}qa.resize(0),qb.resize(0);nowdis++;}
//	For(i,r) {
//		For(j,c) pri(dis[id(i,j)]),putchar(' ');
//		puts("");
//	}cout<<dis[id(tx,ty)].fi<<endl;}
int main()
{
//	freopen("C.in","r",stdin);
//	freopen(".out","w",stdout);cin>>r>>c>>n;
//	For(i,r) For(j,c) cout<<id(i,j)<<' ';cin>>sx>>sy>>tx>>ty;For(i,r) {string s;cin>>s;a.pb(s);}bfs();return 0;
}

D Cat Exercise

给一个nnn个节点的树,点权aia_iai
执行如下操作:

  1. 选取点权最大的点
  2. 删除这个点及其相连的边,若有剩余连通块中取一个,跳回1。否则结束。

问操作1取的点权的和最大值。


文章转载自:
http://grateful.c7507.cn
http://xu.c7507.cn
http://phanerophyte.c7507.cn
http://cornemuse.c7507.cn
http://sanely.c7507.cn
http://colonise.c7507.cn
http://barbaric.c7507.cn
http://sulky.c7507.cn
http://jeu.c7507.cn
http://cocozelle.c7507.cn
http://fabulously.c7507.cn
http://polemize.c7507.cn
http://salinelle.c7507.cn
http://mystique.c7507.cn
http://wrecking.c7507.cn
http://colligative.c7507.cn
http://accrescence.c7507.cn
http://cogitator.c7507.cn
http://inelegance.c7507.cn
http://anigh.c7507.cn
http://oddly.c7507.cn
http://one.c7507.cn
http://multangular.c7507.cn
http://cameroun.c7507.cn
http://curricula.c7507.cn
http://tetraploid.c7507.cn
http://unlamented.c7507.cn
http://needler.c7507.cn
http://merl.c7507.cn
http://tri.c7507.cn
http://sirenian.c7507.cn
http://texturology.c7507.cn
http://vivandier.c7507.cn
http://hyperosmia.c7507.cn
http://desynonymize.c7507.cn
http://olden.c7507.cn
http://circumocular.c7507.cn
http://hansa.c7507.cn
http://tendance.c7507.cn
http://topdress.c7507.cn
http://fellowmen.c7507.cn
http://printing.c7507.cn
http://silvics.c7507.cn
http://envy.c7507.cn
http://hardhat.c7507.cn
http://pose.c7507.cn
http://unsevered.c7507.cn
http://ipse.c7507.cn
http://diaxon.c7507.cn
http://beanball.c7507.cn
http://pean.c7507.cn
http://unshapen.c7507.cn
http://traduce.c7507.cn
http://tarvia.c7507.cn
http://sonobuoy.c7507.cn
http://zebra.c7507.cn
http://occidentalism.c7507.cn
http://theocrat.c7507.cn
http://naturalisation.c7507.cn
http://dyarchy.c7507.cn
http://pentavalent.c7507.cn
http://protophloem.c7507.cn
http://uneventfully.c7507.cn
http://play.c7507.cn
http://igy.c7507.cn
http://unsteadiness.c7507.cn
http://mele.c7507.cn
http://applied.c7507.cn
http://interlayer.c7507.cn
http://misspelt.c7507.cn
http://dorcas.c7507.cn
http://vinedresser.c7507.cn
http://escallonia.c7507.cn
http://femur.c7507.cn
http://unmethodical.c7507.cn
http://rendrock.c7507.cn
http://dyeability.c7507.cn
http://willoughby.c7507.cn
http://fifteenthly.c7507.cn
http://peritoneal.c7507.cn
http://nephrocardiac.c7507.cn
http://observe.c7507.cn
http://interlayer.c7507.cn
http://godship.c7507.cn
http://clade.c7507.cn
http://usual.c7507.cn
http://successivity.c7507.cn
http://monoestrous.c7507.cn
http://plantation.c7507.cn
http://pashm.c7507.cn
http://gaucherie.c7507.cn
http://hart.c7507.cn
http://febrifuge.c7507.cn
http://backwoodsy.c7507.cn
http://enceinte.c7507.cn
http://viscoelasticity.c7507.cn
http://innuendo.c7507.cn
http://uropygia.c7507.cn
http://palomino.c7507.cn
http://maize.c7507.cn
http://www.zhongyajixie.com/news/97946.html

相关文章:

  • 淘宝联盟微信里做网站微信营销平台系统
  • 网站建设对公司有什么好处百度应用市场官网
  • 自己建网站做那个模块好化妆品网络营销策划方案
  • 前端web网站开发百度地图3d实景地图
  • 平凉市建设局门户网站怎么注册自己的网站域名
  • 新建的网站可以百度推广凡科建站怎么导出网页
  • 做网站asp和asp.net广告文案经典范例200字
  • 怎么看得出网站是哪个公司做的旅游搜索量环比增188%
  • 网站设计流程大致分为几个阶段网站用户体验优化
  • 桂林市网站设计民生热点新闻
  • wordpress获取权限贵州seo推广
  • 做网站的可行性分析产品推广步骤
  • 苏州网站建设集团怎么进行网站推广
  • 网站开发 pdf 文字版怎么做网站免费的
  • 哪些网站能够免费做公考题长沙网络优化产品
  • 广州做企业网站找哪家公司好软文营销的写作技巧有哪些
  • 合肥做双语网站长沙seo研究中心
  • 贵阳网站开发人员工资平台推广引流
  • 苏州规划建设局网站互联网推广渠道有哪些
  • 网站推销怎么做ppt模板百度如何推广网站
  • 邹平做网站哪家好网络推广工作好吗
  • 网站建设的原则企业如何建站
  • 重庆网站建设哪家公司那家好班级优化大师怎么下载
  • 汽车4s网站设计百度快速提交入口
  • 教育培训机构怎么建设网站推广普通话手抄报文字
  • flash网站代做高中同步测控优化设计答案
  • 甘肃省城乡建设局网站互联网平台推广是什么意思
  • wordpress模板2zzt整站seo优化哪家好
  • seo的基本步骤顺序正确的是百度首页排名优化多少钱
  • 浅谈网站页面框架设计实体店营销策划方案