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

做网站要学那些东西公司营销策划方案

做网站要学那些东西,公司营销策划方案,动画设计专业就业前景怎么样,公司网站实名制考场错误: A题其实并不简单,但是先想了一个方法后,就交了,wa了后一直卡住,策略不当,到最后后期写C的时候也犯了一些低级的错误,这点需要注意。 之后顺利的把BCDHI写完后,又完成了A的…

考场错误:
A题其实并不简单,但是先想了一个方法后,就交了,wa了后一直卡住,策略不当,到最后后期写C的时候也犯了一些低级的错误,这点需要注意。
之后顺利的把BCDHI写完后,又完成了A的改正补充,最后又把G完成了,最终做出了7个题,但罚时最多,应该注意正确率

Gym - 100738E

启发式合并的模板题,其实看到25次的限制,就应该想到应该和log有关,结合最小生成树的Kruskal的算法,把边权排序一个一个做合并就可以了,注意每次选择sz小的往sz大的上面合并就好了

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=2e5+5;
int n,m;
struct edge
{int x,y,z;
}e[maxn<<1];
int fa[maxn],bus[maxn];
vector <int> driver[maxn];
bool cmp(edge x,edge y)
{return x.z<y.z;
}
int find(int x)
{if(x==fa[x]) return x;return fa[x]=find(fa[x]);
}
vector <int> G[maxn];
int gs;
ll res;
void print(int u,int ff)
{for(int to:G[u]){if(to==ff) continue;print(to,u);if(driver[bus[to]].size()>driver[bus[u]].size())swap(bus[u],bus[to]);for(int v:driver[bus[to]]){driver[bus[u]].push_back(v);printf("Move %d %d %d\n",v,bus[to],bus[u]);}}if(ff) printf("Drive %d %d %d\n",bus[u],u,ff);
}
int main()
{scanf("%d%d",&n,&m);for(int i=1;i<=m;i++) scanf("%d%d%d",&e[i].x,&e[i].y,&e[i].z);for(int i=1;i<=n;i++) fa[i]=i,bus[i]=i,driver[i].push_back(i);sort(e+1,e+m+1,cmp);for(int i=1;i<=m;i++){int fx=find(e[i].x),fy=find(e[i].y);if(fx==fy) continue;fa[fx]=fy;res+=e[i].z;G[e[i].x].push_back(e[i].y);G[e[i].y].push_back(e[i].x);gs++; if(gs==n-1) break;}printf("%lld\n",res);for(int i=1;i<=n;i++) fa[i]=i;print(1,0);printf("Done\n");return 0;
}

Gym - 100738F

后缀数组的裸题,可以使用后缀数组后
然后把询问离线,按照长度依次处理,对于同一个长度,二分配合树状数组计算即可

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+5;
int n;
char s[maxn];
int sa[maxn],rk[maxn],cnt[maxn],fz[maxn];
int oldrk[maxn],id[maxn];
bool cmp(int x,int y,int w)
{return oldrk[x]==oldrk[y] && oldrk[x+w]==oldrk[y+w];
}
void SA()
{int m=233;for(int i=0;i<=m;i++) cnt[i]=0;for(int i=1;i<=n;i++) cnt[rk[i]=s[i]]++;for(int i=1;i<=m;i++) cnt[i]+=cnt[i-1];for(int i=n;i>=1;i--) sa[cnt[rk[i]]--]=i;int i,p;for(int w=1;;w<<=1,m=p){for(p=0,i=n;i>n-w;i--) id[++p]=i;for(i=1;i<=n;i++) if(sa[i]>w) id[++p]=sa[i]-w;for(i=0;i<=m;i++) cnt[i]=0;for(i=1;i<=n;i++) cnt[fz[i]=rk[id[i]]]++;for(i=1;i<=m;i++) cnt[i]+=cnt[i-1];for(i=n;i>=1;i--) sa[cnt[fz[i]]--]=id[i];for(i=1;i<=n;i++) oldrk[i]=rk[i];for(p=0,i=1;i<=n;i++) rk[sa[i]]=cmp(sa[i],sa[i-1],w)?p:++p;if(p==n){for(i=1;i<=n;i++) sa[rk[i]]=i;break;}}
}
struct Query
{int id,l,k;
}q[maxn];
int Q;
bool ccmp(Query x,Query y)
{return x.l<y.l;
}
int c[maxn];
int lowbit(int x)
{return x&-x;
}
void add(int pos,int x)
{while(pos<=n){c[pos]+=x;pos+=lowbit(pos);}
}
int ask(int pos)
{int res=0;while(pos){res+=c[pos];pos-=lowbit(pos);}return res;
}
int res[maxn];
int main()
{scanf("%s",s+1);n=strlen(s+1);SA();scanf("%d",&Q);for(int i=1;i<=Q;i++){scanf("%d%d",&q[i].l,&q[i].k);q[i].id=i;} sort(q+1,q+Q+1,ccmp);int now=1;for(int i=1;i<=Q;i++){while(now<q[i].l){add(rk[n-now+1],1);now++;}int l=1,r=n,ans=0;while(l<=r){int mid=l+r>>1;if(mid-ask(mid)>=q[i].k) ans=mid,r=mid-1;else l=mid+1;}res[q[i].id]=sa[ans];}for(int i=1;i<=Q;i++) printf("%d\n",res[i]);return 0;
}
http://www.yayakq.cn/news/77203/

相关文章:

  • 东莞东城网站建设公司wordpress主题大前端
  • 钻井网站建设泉州学校网站建设
  • 廊坊网站网络推广外包公司
  • 模板网站建设套餐网站建设价格费用
  • 网站建设实训小组报告wordpress the_field
  • 网站根目录 本地共享软件推广平台有哪些?哪个比较好
  • 创建网站的软件什么梦做我的世界头像的网站
  • 企业网站推广哪家好怎么让网站分享有图片
  • 网站一般用什么免费字体wordpress story 模板
  • 灵犀科技网站建设企业邮箱注册哪个好
  • 网站建设优化佛山黄冈做网站
  • 外贸怎么做公司网站外贸WordPress主机推荐
  • 北京南站地铁自己可以模拟装修app
  • 网站怎么做友链网页制作网站花店
  • 自助建站免费建站五个平台学网站开发的软件有哪些
  • 自己怎么做单页网站wordpress滑动
  • 西安医疗网站建设网站备案IP与空间
  • ps做网站导航条高度珠海网站建设公司
  • 深圳企业网站app开发wordpress 批量导入
  • 软件 行业门户网站网站开发的基本知识
  • 深圳网站程序开发网站升级改版需要几天
  • 周到的网站建设推广什么叫软件外包公司
  • 东莞高端网站建设公司哪家好设计公司企业标语
  • 做数据ppt模板下载网站茂名专业做网站公司
  • 网站建设公司选择标准手机版网站制作应用
  • 房产中介网站排名wordpress有名的网站
  • 官方网站建设状况亚马逊图书官网
  • 自己做的微课上传到哪个网站汉中免费做网站公司
  • 网站开发 在html标记后出现乱码 查看源文件显示是问好wordpress 通讯录插件
  • 阿里云备案 网站备案域名自建网站模板代码