Link:

Codeoforces #188 传送门

A:

先全转为正数,后面就全是指数级增长了

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
ll x,y,m,res; int main()
{
cin>>x>>y>>m;
if(max(x,y)<m&&max(x,y)<=)
return puts("-1"),; while(x<m&&y<m)
{
if(x>y) swap(x,y);
ll t=(y-x)/y+;
res+=t;x+=t*y;
}
cout<<res;
return ;
}

Problem A

不断将$(x,y)$改为$(x+y,x)$要分类,在一数为负数时为线性增长

B:

首先要发现最终不为0的点的$x,y$的范围仅不到$[-100,100]$

又由于最终状态和操作顺序无关,因此每次将可能区域内的点暴力更新即可

不过我一开始使用了$bfs$,导致同一个位置可能每次进栈多次从而TLE……

以后$bfs$在同一层时一定要控制每个数的进栈次数!能每个位置暴力就不要$bfs$

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int ZERO=;
int n,t,x,y,a[*ZERO][*ZERO],flag=;
int dx[]={,,,-},dy[]={,-,,}; int main()
{
scanf("%d%d",&n,&t);
a[ZERO][ZERO]=n;
while(flag)
{
flag=;
for(int i=ZERO-;i<=ZERO+;i++)
for(int j=ZERO-;j<=ZERO+;j++)
if(a[i][j]>=)
{
flag=;
for(int k=;k<;k++)
a[i+dx[k]][j+dy[k]]+=a[i][j]/;
a[i][j]%=;
}
}
while(t--)
scanf("%d%d",&x,&y),printf("%d\n",abs(x)<=ZERO&&abs(y)<=ZERO?a[ZERO+x][ZERO+y]:);
return ;
}

Problem B

C:

其实是一道不算难的模拟题?可能当时被吓到了……

只要每个连通块里保证收支平衡就保证有解

接下来可以暴力枚举点对转移,保证是将多出的转入少的中,这样就可以忽略上限这个条件了

但也可以总共$O(n^2)$得做:

由于转移次数上限为$O(2*n^2)$,因此可以仅将每个连通块连成一棵树

将一个当前不够的点作为根先做一个预处理,只要$O(n)$的遍历就能使该点符合条件

过程中注意保证已经符合条件的点不能改变,将当前多出的转移

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=2e5+;
struct edge{int nxt,to;}e[MAXN<<];
struct result{int x,y,val;}res[MAXN<<];
int n,v,m,x,y,a[MAXN],b[MAXN],f[MAXN],head[MAXN],tot,cnt;ll sum[MAXN]; int find(int x)
{return f[x]==x?x:f[x]=find(f[x]);}
void add_edge(int x,int y)
{e[++tot]={head[x],y};head[x]=tot;e[++tot]={head[y],x};head[y]=tot;}
void add_res(int x,int y,int val)
{a[x]-=val,a[y]+=val,res[++cnt]={x,y,val};} void dfs(int x,int anc)
{
sum[x]=a[x]-b[x];
for(int i=head[x];i;i=e[i].nxt)
if(e[i].to!=anc) dfs(e[i].to,x),sum[x]+=sum[e[i].to];
}
void solve(int x,int anc,int val)
{
for(int i=head[x];i;i=e[i].nxt)
{
if(e[i].to==anc||sum[e[i].to]<=) continue;
int w=sum[e[i].to]<val?sum[e[i].to]:val,tmp=a[e[i].to];
if(tmp>=w)
{
add_res(e[i].to,x,w);
if(a[e[i].to]<b[e[i].to]&&tmp>=b[e[i].to])
solve(e[i].to,x,b[e[i].to]-a[e[i].to]);
}
else
{
add_res(e[i].to,x,tmp);
if(tmp<b[e[i].to]) solve(e[i].to,x,w-tmp);
else solve(e[i].to,x,w-tmp+b[e[i].to]);
add_res(e[i].to,x,w-tmp);
}
val-=w;if(!val) return;
}
} int main()
{
scanf("%d%d%d",&n,&v,&m);
for(int i=;i<=n;i++) f[i]=i;
for(int i=;i<=n;i++) scanf("%d",&a[i]);
for(int i=;i<=n;i++) scanf("%d",&b[i]);
for(int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
int posx=find(x),posy=find(y);
if(posx!=posy) add_edge(x,y),f[posx]=posy;
}
for(int i=;i<=n;i++) sum[find(i)]+=a[i]-b[i];
for(int i=;i<=n;i++) if(sum[i]) return puts("NO"),; for(int i=;i<=n;i++)
if(a[i]<b[i]) dfs(i,),solve(i,,b[i]-a[i]);
printf("%d\n",cnt);
for(int i=;i<=cnt;i++)
printf("%d %d %d\n",res[i].x,res[i].y,res[i].val);
return ;
}

Problem C

D:

很明显的一道博弈论

找到所有极大的集合${X^s}$,对每个集合求$SG$值最后异或即可

其中数量大于2的集合可以$sqrt(n)$得找出,剩下数量为1的$SG=1$,可以统一计算

同时$SG$值仅和集合内数量相关,可以预处理+打表

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int mx=,MAXN=1e5+;
//unordered_map<int,int> mp;
int n,k,pre[],vis[MAXN],rem,res;
int sg[]={,,,,,,,,,,,,,,,,,,,,,,,,,,,,,};
/*
int solve(int x)
{
int &tmp=mp[x];
if(tmp) return tmp;
int ret=(1<<mx)-1;
for(int i=1;(1<<(i-1))<=x;i++)
if(x&(1<<(i-1)))
ret&=~solve(x&~pre[i]);
return tmp=ret&(-ret);
}
*/
int main()
{
/*
for(int i=1;i<=mx;i++)
for(int j=i;j<=mx;j+=i)
pre[i]|=(1<<(j-1));
mp.max_load_factor(0.30);
mp.reserve(750000);
for(int i=1;i<mx;i++)
sg[i]=__builtin_ctz(solve((1<<i)-1));
*/
scanf("%d",&n);
rem=n;res=;
for(int i=;i*i<=n;i++)
if(!vis[i])
{
k=;
for(ll j=i;j<=n;j*=i,k++)
if(j*j<=n) vis[j]=;
rem-=k;res^=sg[k];
}
res^=(rem&);
puts(res?"Vasya":"Petya");
return ;
}

Problem D

与次方相关的注意将大于1的和1次方分开考虑

注意该题各种位运算技巧和$unordered\_ map$以及$builtin\_ ctz,reserve(),max\_load\_factor$的使用

E:

[Codeforces #188] Tutorial的更多相关文章

  1. [Codeforces #172] Tutorial

    Link: Codeforces #172 传送门 A: 一眼看上去分两类就可以了 1.每个矩形只有两条边相交,重合的形状为菱形 2.每个矩形四条边都有相交 对于情况1答案为$h*h/sin(a)$ ...

  2. [Codeforces #514] Tutorial

    Link: Codeforces #514 传送门 很简单的一场比赛打崩了也是菜得令人无话可说…… D: 一眼二分,发现对于固定的半径和点,能包含该点的圆的圆心一定在一个区间内,求出区间判断即可 此题 ...

  3. [Codeforces #210] Tutorial

    Link: Codeforces #210 传送门 A: 贪心,对每个值都取最大值,不会有其他解使答案变优 #include <bits/stdc++.h> using namespace ...

  4. [Codeforces #196] Tutorial

    Link: Codeforces #196 传送门 A: 枚举 #include <bits/stdc++.h> using namespace std; #define X first ...

  5. [Codeforces #174] Tutorial

    Link: Codeforces #174 传送门 A: 求原根的个数,有一条性质是原根个数为$\phi(\phi(n))$,多了一个不会证的性质 如果要确定哪些是原根的话还是要枚举,不过对于每个数不 ...

  6. [Codeforces #190] Tutorial

    Link: Codeforces #190 传送门 A: 明显答案为$n+m-1$且能构造出来 #include <bits/stdc++.h> using namespace std; ...

  7. [Codeforces #211] Tutorial

    Link: Codeforces #211 传送门 一套非常简单的题目,但很多细节都是错了一次才能发现啊…… 还是不能养成OJ依赖症,交之前先多想想corner case!!! A: 模拟,要特判0啊 ...

  8. [Codeforces #192] Tutorial

    Link: Codeforces #192 传送门 前两天由于食物中毒现在还要每天挂一天的水 只好晚上回来随便找套题做做找找感觉了o(╯□╰)o A: 看到直接大力模拟了 但有一个更简便的方法,复杂度 ...

  9. [Codeforces #201] Tutorial

    Link: 传送门 代码量很少的一套思维题 A: 试一试发现最后状态一定是所有$min,max$间$gcd$的倍数 直接判断数量的奇偶性即可 #include <bits/stdc++.h> ...

随机推荐

  1. SVG(可缩放矢量图形)

        SVG可缩放矢量图形(Scalable Vector Graphics)是基于可扩展标记语言(XML),用于描述二维矢量图形的一种图形格式.SVG是W3C("World Wide W ...

  2. 分布式实时日志分析解决方案ELK部署架构

    一.概述 ELK 已经成为目前最流行的集中式日志解决方案,它主要是由Beats.Logstash.Elasticsearch.Kibana等组件组成,来共同完成实时日志的收集,存储,展示等一站式的解决 ...

  3. Kaggle机器学习之模型集成(stacking)

    Stacking是用新的模型(次学习器)去学习怎么组合那些基学习器,它的思想源自于Stacked Generalization这篇论文.如果把Bagging看作是多个基分类器的线性组合,那么Stack ...

  4. linux内核启动分析(3)

    主要分析do_basic_setup函数里面的do_initcalls()函数,这个函数用来调用所有编译内核的驱动模块中的初始化函数. static void __init do_initcalls( ...

  5. 实现点击页面其他地方,隐藏div(vue)

    方法一: 通过监听事件 document.addEventListener('click',function(e){ if(e.target.className!='usermessage'){ th ...

  6. FineReport——JS二次开发(自定义翻页按钮)

    FR允许自定义工具栏上面的按钮,并提交JS方法: 对于翻页功能,大概有首页,下一页,上一页,最后一页,以及跳转页等功能. 不得不说的是,在HTML页面自定义的按钮如何获取到报表模板,通过FR提供的JS ...

  7. hdu 3416(最大流+最短路)

    Marriage Match IV Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  8. NYOJ 116 士兵杀敌二

    士兵杀敌(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:5   描述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的. 小工是南将军手下的军师,南将军经常 ...

  9. Divide Two Integers——二分法的经典变形

    Divide two integers without using multiplication, division and mod operator. If it is overflow, retu ...

  10. 181. Employees Earning More Than Their Managers

    The Employee table holds all employees including their managers. Every employee has an Id, and there ...