题面:https://www.cnblogs.com/Juve/articles/11678564.html

简单的操作:

考场上sb了,没看出来

如果有奇环一定不能缩成一条链,判掉奇环后就是bfs最短路了

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int MAXN=;
const int MAXM=1e5+;
int n,m,col[MAXN],tot=,ans=,bel[MAXN],res[MAXN];
int to[MAXM<<],nxt[MAXM<<],pre[MAXN],cnt=;
void add(int u,int v){
++cnt,to[cnt]=v,nxt[cnt]=pre[u],pre[u]=cnt;
}
bool dfs(int x,int c){
col[x]=c,bel[x]=tot;
for(int i=pre[x];i;i=nxt[i]){
int y=to[i];
if(col[y]==c) return ;
else if((!col[y])&&(!dfs(y,-c))) return ;
}
return ;
}
int dis[MAXN];
void bfs(int st){
memset(dis,,sizeof(dis));
queue<int>q;
dis[st]=;
q.push(st);
while(!q.empty()){
int x=q.front();
q.pop();
for(int i=pre[x];i;i=nxt[i]){
int y=to[i];
if(dis[y]==){
dis[y]=dis[x]+;
q.push(y);
}
}
}
}
int main(){
scanf("%d%d",&n,&m);
for(int i=,u,v;i<=m;++i){
scanf("%d%d",&u,&v);
add(u,v),add(v,u);
}
for(int i=;i<=n;++i){
if(!col[i]){
++tot;
if(!dfs(i,)){
ans=-;
break;
}
}
}
if(ans==-){
printf("%d\n",ans);
return ;
}
for(int i=;i<=n;++i){
bfs(i);
for(int j=;j<=n;++j){
res[bel[i]]=max(res[bel[i]],dis[j]-);
}
}
for(int i=;i<=tot;++i){
ans+=res[i];
}
printf("%d\n",ans);
return ;
}

2048:

话说我不会2048考场上是不是爆0了?

就是模拟

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int n,m,mp[][],ans=;
bool flag=,vis[][];
int get(){
int res=;
for(int i=;i<=n;++i){
for(int j=;j<=n;++j)
res+=(mp[i][j]==);
}
return res;
}
void put(int pos,int val){
for(int i=;i<=n;++i){
for(int j=;j<=n;++j){
if(mp[i][j]!=) continue;
--pos;
if(pos==){
mp[i][j]=val;
return ;
}
}
}
}
void mergeup(){
for(int i=;i<=n;++i){
for(int j=;j<=n;++j){
if(mp[i][j]==) continue;
int p=i-,k=mp[i][j];
while(p>&&mp[p][j]==) mp[p][j]=k,mp[p+][j]=,--p;
if(p!=i-) flag=;
if(vis[p][j]==&&mp[p+][j]==mp[p][j]) mp[p][j]<<=,mp[p+][j]=,flag=vis[p][j]=,ans+=mp[p][j];
}
}
}
void up(){
for(int i=;i<=n;++i){
for(int j=;j<=n;++j){
if(mp[i][j]==) continue;
int p=i-,k=mp[i][j];
while(p>&&mp[p][j]==) mp[p][j]=k,mp[p+][j]=,--p;
if(p!=i-) flag=;
}
}
}
void mergedown(){
for(int i=n-;i>=;--i){
for(int j=;j<=n;++j){
if(mp[i][j]==) continue;
int p=i+,k=mp[i][j];
while(p<=n&&mp[p][j]==) mp[p][j]=k,mp[p-][j]=,++p;
if(p!=i+) flag=;
if(vis[p][j]==&&mp[p-][j]==mp[p][j]) mp[p][j]<<=,mp[p-][j]=,flag=vis[p][j]=,ans+=mp[p][j];
}
}
}
void down(){
for(int i=n-;i>=;--i){
for(int j=;j<=n;++j){
if(mp[i][j]==) continue;
int p=i+,k=mp[i][j];
while(p<=n&&mp[p][j]==) mp[p][j]=k,mp[p-][j]=,++p;
if(p!=i+) flag=;
}
}
}
void mergeleft(){
for(int j=;j<=n;++j){
for(int i=;i<=n;++i){
if(mp[i][j]==) continue;
int p=j-,k=mp[i][j];
while(p>&&mp[i][p]==) mp[i][p]=k,mp[i][p+]=,--p;
if(p!=j-) flag=;
if(vis[i][p]==&&mp[i][p]==mp[i][p+]) mp[i][p]<<=,mp[i][p+]=,flag=vis[i][p]=,ans+=mp[i][p];
}
}
}
void left(){
for(int j=;j<=n;++j){
for(int i=;i<=n;++i){
if(mp[i][j]==) continue;
int p=j-,k=mp[i][j];
while(p>&&mp[i][p]==) mp[i][p]=k,mp[i][p+]=,--p;
if(p!=j-) flag=;
}
}
}
void mergeright(){
for(int j=n-;j>=;--j){
for(int i=;i<=n;++i){
if(mp[i][j]==) continue;
int p=j+,k=mp[i][j];
while(p<=n&&mp[i][p]==) mp[i][p]=k,mp[i][p-]=,++p;
if(p!=j+) flag=;
if(vis[i][p]==&&mp[i][p]==mp[i][p-]) mp[i][p]<<=,mp[i][p-]=,flag=vis[i][p]=,ans+=mp[i][p];
}
}
}
void right(){
for(int j=n-;j>=;--j){
for(int i=;i<=n;++i){
if(mp[i][j]==) continue;
int p=j+,k=mp[i][j];
while(p<=n&&mp[i][p]==) mp[i][p]=k,mp[i][p-]=,++p;
if(p!=j+) flag=;
}
}
}
int main(){
scanf("%d%d",&n,&m);
int xx1,yy1,vv1,xx2,yy2,vv2;
scanf("%d%d%d%d%d%d",&xx1,&yy1,&vv1,&xx2,&yy2,&vv2);
mp[xx1][yy1]=vv1,mp[xx2][yy2]=vv2;
for(int i=,d,k,v;i<=m;++i){
scanf("%d%d%d",&d,&k,&v);
memset(vis,,sizeof(vis));
flag=;
if(d==) mergeup(),up();
if(d==) mergedown(),down();
if(d==) mergeleft(),left();
if(d==) mergeright(),right();
if(!flag){
printf("%d\n%d\n",i-,ans);
return ;
}
put(k%get()+,v);
}
printf("%d\n%d\n",m,ans);
return ;
}

数列:

可以证明最优答案要么是单增,要么先增后减

然后就是最长上升子序列了,好像也不太一样,都差不多

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define int long long
using namespace std;
const int MAXN=1e5+;
int n,a[MAXN],b[MAXN],f[MAXN],g[MAXN],mx=;
int lsh[MAXN];
double ans=0.0;
struct BIT{
int c[MAXN];
int lowbit(int x){
return x&(-x);
}
int update(int pos,int val){
for(int i=pos;i<=mx;i+=lowbit(i)){
c[i]=max(c[i],val);
}
}
int query(int pos){
int res=;
for(int i=pos;i>;i-=lowbit(i)){
res=max(res,c[i]);
}
return res;
}
}t1,t2;
double max(double a,double b){
return a>b?a:b;
}
signed main(){
scanf("%lld",&n);
for(int i=;i<=n;++i){
scanf("%lld",&a[i]);
lsh[i]=a[i];
}
sort(lsh+,lsh+n+);
mx=unique(lsh+,lsh+n+)-lsh-;
for(int i=;i<=n;++i) b[i]=lower_bound(lsh+,lsh+mx+,a[i])-lsh;
for(int i=;i<=n;++i){
f[i]=t1.query(b[i]-)+a[i];
g[i]=t2.query(b[n-i+]-)+a[n-i+];
t1.update(b[i],f[i]);
t2.update(b[n-i+],g[i]);
}
for(int i=;i<=n;++i)
ans=max(ans,max(f[i],(f[i]+g[n-i+]-a[i])/2.0));
printf("%0.3lf\n",ans);
return ;
}

生成树:

连虚数都出来了。。。

把每一个虚数看作向量,枚举角度更新答案

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int MAXN=;
const int MAXM=;
int n,m,fa[MAXN];
double ans=0.0,xx,yy;
int find(int x){
return fa[x]=(fa[x]==x?x:find(fa[x]));
}
struct node{
int fr,to;
double a,b;
friend bool operator < (node p,node q){
return p.a*xx+p.b*yy<q.a*xx+q.b*yy;
}
}e[MAXM];
double kruskal(){
int vala=,valb=,sum=;
for(int i=;i<=n;++i) fa[i]=i;
sort(e+,e+m+);
for(int i=;i<=m;++i){
int x=find(e[i].fr),y=find(e[i].to);
if(x!=y){
fa[x]=y;
++sum,vala+=e[i].a,valb+=e[i].b;
if(sum==n-) break;
}
}
return sqrt(vala*vala+valb*valb);
}
int main(){
scanf("%d%d",&n,&m);
for(int i=,u,v;i<=m;++i){
double a,b;
scanf("%d%d%lf%lf",&u,&v,&a,&b);
e[i]=(node){u,v,a,b};
}
for(double i=0.0;i<=63.00;i+=0.01){
xx=sin(i),yy=cos(i);
ans=max(ans,kruskal());
}
printf("%0.6lf\n",ans);
return ;
}

csps模拟测试7273简单的操作小P的2048小P的单调数列小P的生成树的更多相关文章

  1. csp-s模拟测试98

    csp-s模拟测试98 $T1$??不是我吹我轻松手玩20*20.$T2$装鸭好像挺可做?$T3$性质数据挺多提示很明显? $One$ $Hour$ $Later$ 这$T1$什么傻逼题真$jb$难调 ...

  2. csp-s模拟测试94

    csp-s模拟测试94 一场简单题,打爆了.$T1$脑抽分解质因数准备分子分母消,想了半天发现$jb$互质直接上天,果断码了高精滚蛋.$T2$无脑手玩大样例,突然灵光一闪想到映射到前$K$大小的区间, ...

  3. csp-s模拟测试91

    csp-s模拟测试91 倒悬吃屎的一套题. $T1$认真(?)分析题意发现复杂度不能带$n$(?),计划直接维护答案,考虑操作对答案的影响,未果.突然发现可以动态开点权值线段树打部分分,后来$Tm$一 ...

  4. csp-s模拟测试60

    csp-s模拟测试60       2019-10-05 RT. 又颓又垃圾. 状态低迷,题都交不上去. 交了也是爆零,垃圾玩家没有什么可说的,就是垃圾. A. 嘟嘟噜 $mlogn$的毒瘤做法. 贴 ...

  5. csp-s模拟测试99

    csp-s模拟测试99 九九归一直接爆炸. $T1$一眼板子. $T2$一眼语文题(语文的唯一一次$120+$是给模拟出来的可知我的语文能力). $T3$一眼普及题. ?? Hours Later 板 ...

  6. csp-s模拟测试97

    csp-s模拟测试97 猿型毕露.水题一眼秒,火题切不动,还是太菜了. $T1$看了一会儿感觉$woc$期望题$T1??$假的吧??. $T2$秒. $T3$什么玩意儿. 40 01:24:46 00 ...

  7. csp-s模拟测试95

    csp-s模拟测试95 去世场祭. $T1$:这不裸的除法分块吗. $T2$:这不裸的数据结构优化$Dp$吗. $T3$:这不裸的我什么都不会搜索骗$30$分吗. 几分钟后. 这除法分块太劲了..(你 ...

  8. csp-s模拟测试93

    csp-s模拟测试93 自闭场. $T1$想到$CDQ$,因为复杂度少看见一个$0$打了半年还用了$sort$直接废掉,$T2$,$T3$直接自闭暴力分都没有.考场太慌了,心态不好. 02:07:34 ...

  9. csp-s模拟测试89

    csp-s模拟测试89 $T1$想了一会儿没什么思路,一看$T2$  $1e18$当场自闭打完暴力就弃了,$T3$看完题感觉要求$lca$和$dep$,手玩了一下样例发现$lca$很显然,$dep$貌 ...

随机推荐

  1. TCP/IP点滴

    1 子网的划分 2 子网的表述 ipv4 IPv4中规定IP地址长度为32,最大地址个数为2^32,点分十进制表示方法:122.70.156.25. ipv6 地址的长度为128,即最大地址个数为2^ ...

  2. 剑指offer——29顺时针打印矩阵

    题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数 ...

  3. 剑指offer——25链表中环的入口节点

    题目描述 给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null.   题解: 使用快慢指针即可,若快慢指针会相遇,则有环,否则快指针先到空节点: 此时,快指针从此处一次移一步遍历, ...

  4. Python3实用编程技巧进阶✍✍✍

    Python3实用编程技巧进阶  整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课程本身没问题,大家看的时候可以 ...

  5. vue echarts 给饼图中间添加文字 ,并且添加多个样式

    最近根据设计要求写了一个统计图,以下是设计要求,要求中间文字分别是总数和汉字,样式分别不同 好吧具体的解决方案如下 方案一 series: [ { type:'pie', radius: ['50%' ...

  6. php 执行mysql inset 指令无效

    网数据库里插入一条 inset into je_user("name","va") values("df","12"), ...

  7. css3 动画属性

    transition Internet Explorer 9 以及更早版本的浏览器不支持 transition 属性. Internet Explorer 10.Firefox.Opera 和 Chr ...

  8. OC开发系列-@property和@synthesize

    property和synthesize 创建一个Person类.提供成员属性的_age和_height的setter和getter方法. #import <Foundation/Foundati ...

  9. 《软件调试修炼之道》Part 1(CH1~5)读书笔记 PB16110698 第八周(~4.26)

    编程中,调试几乎是必不可少的,一劳永逸.一次完成预想功能而完全不出bug的情况凤毛麟角,出现bug→调试→再出现bug→再调试……基本是软件工程中的常态.可以说,软件调试是每个coder的必修课,而& ...

  10. ASP.NET MVC easyUI-datagrid 的当前页合计and总合计

    一.HTML代码 <table id="dg" class="easyui-datagrid" style="width: 100%; heig ...