Solution Set -「ABC 193」
「ABC 193A」Discount
Link.
略。
#include<cstdio>
int main()
{
int a,b;
scanf("%d %d",&a,&b);
printf("%.2f\n",(1.0-(double)b/(double)a)*100.0);
return 0;
}
「ABC 193B」Play Snuke
Link.
排序。
#include<cstdio>
#include<algorithm>
using namespace std;
struct node
{
int tim,pay,ps;
}nodes[100010];
bool cmp(node one,node ano)
{
return one.pay<ano.pay;
}
int ans=-1;
int main()
{
int n;
scanf("%d",&n);
for(int i=1;i<=n;++i) scanf("%d %d %d",&nodes[i].tim,&nodes[i].pay,&nodes[i].ps);
sort(nodes+1,nodes+n+1,cmp);
for(int i=1;i<=n;++i)
{
if(((int)((double)nodes[i].tim-0.5)+1)<nodes[i].ps)
{
ans=nodes[i].pay;
break;
}
}
printf("%d\n",ans);
return 0;
}
「ABC 193C」Unexpressed
Link.
可以容斥,也可以暴力枚举 std::set 去重。
#include<set>
#include<iostream>
#define int long long
using namespace std;
set<int> app;
signed main()
{
int n,ians=0;
cin>>n;
for(int i=2;i*i<=n;++i)
{
for(int j=i*i;j<=n;j*=i)
{
if(!app.count(j))
{
++ians;
app.insert(j);
}
}
}
cout<<n-ians;
return 0;
}
「ABC 193D」Poker
Link.
开个答案+单位贡献的结构体,然后模拟。
#include<iostream>
#include<iomanip>
using namespace std;
#define int long long
#define ID(c) ((c)-'0')
int k,num[20];
char s[20],t[20];
struct node
{
int iths[20],sum,c[20];
int spow(int fur)
{
int res=1;
for(int i=1;i<=fur;++i) res*=10;
return res;
}
void getscor(char x[])
{
for(int i=1;i<=4;++i) ++c[ID(x[i])];
for(int i=1;i<=9;++i)
{
iths[i]=i*spow(c[i]);
sum+=iths[i];
}
}
void Op(int pos,int delta)
{
c[pos]+=delta;
sum-=iths[pos];
if(~delta) iths[pos]*=10;
else iths[pos]/=10;
sum+=iths[pos];
}
}tak,aok;
signed main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>k>>(s+1)>>(t+1);
for(int i=1;i<=9;++i) num[i]=k;
for(int i=1;i<=4;++i) --num[ID(s[i])],--num[ID(t[i])];
tak.getscor(s);
aok.getscor(t);
int winans=0,allans=0;
for(int i=1;i<=9;++i)
{
for(int j=1;j<=9;++j)
{
tak.Op(i,1);
aok.Op(j,1);
if(tak.sum>aok.sum)
{
if(i^j) winans+=num[i]*num[j];
else winans+=num[i]*(num[j]-1);
}
tak.Op(i,-1);
aok.Op(j,-1);
}
}
for(int i=1;i<=9;++i)
{
for(int j=1;j<=9;++j)
{
if(i^j) allans+=num[i]*num[j];
else allans+=num[i]*(num[j]-1);
}
}
cout<<fixed<<setprecision(6)<<(double)winans/(double)allans<<endl;
return 0;
}
「ABC 193E」Oversleeping
Link.
开始想到计算几何去了,打了很久。
实际上因为 \(500\) 的范围,你可以直接枚举余数然后 exCRT 合并。
#include<cstdio>
#include<climits>
#include<algorithm>
using namespace std;
typedef long long LL;
const LL INF=LONG_LONG_MAX;
namespace NumbTheo
{
LL ftimes(LL bas,LL fur,LL mod)
{
LL res=0;
while(fur)
{
if(fur&1) res=(res+bas)%mod;
bas=(bas+bas)%mod,fur>>=1;
}
return res;
}
LL exGCD(LL one,LL ano,LL &x,LL &y)
{
if(ano==0) return (x=1,y=0,one);
else
{
LL tmp=exGCD(ano,one%ano,y,x);
y-=(one/ano)*x;
return tmp;
}
}
LL exCRT(LL n,LL one[],LL ano[])
{
LL x,y,res=one[1],M=ano[1];
for(int i=2;i<=n;++i)
{
LL a=M,b=ano[i],c=(one[i]-res%b+b)%b,tmp=exGCD(a,b,x,y),d=b/tmp;
if(c%tmp) return -1;
x=ftimes(x,c/tmp,d);
res+=x*M,M*=d,res=(res%M+M)%M;
}
return (res%M+M)%M;
}
};
int t;
LL one[10],ano[10],ans;
int main()
{
scanf("%d",&t);
while(t--)
{
LL X,Y,P,Q;
scanf("%lld %lld %lld %lld",&X,&Y,&P,&Q);
ans=INF;
for(LL i=X;i<X+Y;++i)
{
for(int j=P;j<P+Q;++j)
{
using namespace NumbTheo;
one[1]=i,ano[1]=((X+Y)<<1),one[2]=j,ano[2]=P+Q;
LL tmp=exCRT(2,one,ano);
if(~tmp) ans=min(ans,tmp);
}
}
if(ans==INF) printf("infinity\n");
else printf("%lld\n",ans);
}
return 0;
}
「ABC 193F」Zebraness
Link.
把 \(i+j\) 为奇数的地方反转一下,然后连边求最小割。
#include<queue>
#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long LL;
#define getID(x,y) (((x)-1)*n+(y))
namespace MaxFlow
{
queue<int> q;
const LL INF=1e9;
int S,T,head[10010],Cur[10010],cntot=1,all,vis[10010];
LL dep[10010];
struct Edge
{
int to,nxt;
LL c;
Edge(int A=0,int B=0,LL C=0){to=A,nxt=B,c=C;}
}as[500010];
bool bfs()
{
for(int i=1;i<=all;++i) vis[i]=0,dep[i]=INF;
q.push(S),dep[S]=0,vis[S]=1;
while(!q.empty())
{
int now=q.front();
q.pop(),vis[now]=0;
for(int i=head[now];i;i=as[i].nxt)
{
int y=as[i].to;
LL c=as[i].c;
if(c&&dep[y]>dep[now]+1)
{
dep[y]=dep[now]+1;
if(!vis[y]) q.push(y),vis[y]=1;
}
}
}
return dep[T]<INF;
}
LL dfs(int x,LL lav)
{
if(x==T) return lav;
LL used=0;
vis[x]=1;
for(int &i=Cur[x];i;i=as[i].nxt)
{
int y=as[i].to;
LL c=as[i].c;
if(c&&dep[y]==dep[x]+1&&!vis[y])
{
LL tmp=dfs(y,min(lav-used,c));
as[i].c-=tmp,as[i^1].c+=tmp,used+=tmp;
if(lav==used) break;
}
}
if(used<lav) dep[x]=INF;
vis[x]=0;
return used;
}
LL Dinic()
{
LL res=0;
while(bfs())
{
for(int i=1;i<=all;++i) vis[i]=0,Cur[i]=head[i];
res+=dfs(S,INF);
}
return res;
}
}using namespace MaxFlow;
int n;
int rop()
{
char res=getchar();
while((res^'B')&&(res^'W')&&(res^'?')) res=getchar();
if(res=='?') return -1;
else if(res=='B') return 1;
else return 0;
}
void addEdge(int one,int ano,int lav)
{
as[++cntot]=Edge(ano,head[one],lav);
head[one]=cntot;
as[++cntot]=Edge(one,head[ano],0);
head[ano]=cntot;
}
int main()
{
scanf("%d",&n),all=n*n;
S=(++all),T=(++all);
for(int i=1;i<=n;++i)
{
for(int j=1;j<=n;++j)
{
int x=rop();
if(~x)
{
if((i+j)&1) x^=1;
if(x) addEdge(S,getID(i,j),INF);
else addEdge(getID(i,j),T,INF);
}
}
}
for(int i=1;i<n;++i)
{
for(int j=1;j<=n;++j) addEdge(getID(i,j),getID(i+1,j),1),addEdge(getID(i+1,j),getID(i,j),1);
}
for(int i=1;i<=n;++i)
{
for(int j=1;j<n;++j) addEdge(getID(i,j),getID(i,j+1),1),addEdge(getID(i,j+1),getID(i,j),1);
}
printf("%lld\n",2*n*(n-1)-Dinic());
return 0;
}
Solution Set -「ABC 193」的更多相关文章
- Solution Set -「ABC 217」
大家好屑兔子又来啦! [A - Lexicographic Order] 说个笑话,\(\color{black}{\text{W}}\color{red}{\text{alkingDead} ...
- Diary / Solution Set -「WC 2022」线上冬眠做噩梦
大概只有比较有意思又不过分超出能力范围的题叭. 可是兔子的"能力范围" \(=\varnothing\) qwq. 「CF 1267G」Game Relics 任意一个 ...
- Solution Set -「ARC 107」
「ARC 107A」Simple Math Link. 答案为: \[\frac{a(a+1)\cdot b(b+1)\cdot c(c+1)}{8} \] 「ARC 107B」Quadrup ...
- Solution -「ABC 219H」Candles
\(\mathcal{Description}\) Link. 有 \(n\) 支蜡烛,第 \(i\) 支的坐标为 \(x_i\),初始长度为 \(a_i\),每单位时间燃烧变短 \(1\) ...
- Solution -「ABC 215H」Cabbage Master
\(\mathcal{Description}\) Link. 有 \(n\) 种颜色的,第 \(i\) 种有 \(a_i\) 个,任意两球互不相同.还有 \(m\) 个盒子,每个盒子可以被放 ...
- Solution -「ABC 213G」Connectivity 2
\(\mathcal{Description}\) Link. 给定简单无向图 \(G=(V,E)\),点的编号从 \(1\) 到 \(|V|=n\).对于 \(k=2..n\),求 \(H= ...
- Solution -「ABC 213H」Stroll
\(\mathcal{Description}\) Link. 给定一个含 \(n\) 个结点 \(m\) 条边的简单无向图,每条边的边权是一个常数项为 \(0\) 的 \(T\) 次多项式, ...
- Solution -「ABC 217」题解
D - Cutting Woods 记录每一个切割点,每次求前驱后驱就好了,注意简单判断一下开闭区间. 考场上采用的 FHQ_Treap 无脑莽. #include <cstdio> #i ...
- 「ABC 249Ex」Dye Color
考虑停时定理. 初始势能为 \(\sum \Phi(cnt_i)\),末势能为 \(\Phi(n)\),我们希望构造这样一个 \(\Phi:Z\to Z\) 函数,使得每一次操作期望势能变化量为常数. ...
- Note -「Lagrange 插值」学习笔记
目录 问题引入 思考 Lagrange 插值法 插值过程 代码实现 实际应用 「洛谷 P4781」「模板」拉格朗日插值 「洛谷 P4463」calc 题意简述 数据规模 Solution Step 1 ...
随机推荐
- R EnhancedVolcano 绘制火山图
火山图是用于差异表达分析结果可视化的一种有效方法.今天,我们来介绍一个用于增强火山图绘制的强大 R 包:EnhancedVolcano ,该包拥有强大的绘图功能,用户可以简单的通过设置颜色.形状.大小 ...
- CentOS Linux 7 安全基线设置
作为一个生信人,不管是日常的数据分析还是其他工具应用的开发,服务器的安全始终是一个无法避免的话题.尤其是当我们拿到一台新的服务器,我们需要怎样才能确保它是安全可靠,并最小限度降低它被攻击的可能性? 下 ...
- 使用C语言实现简单的通用的链表
在数据结构中,我们已经学习到了简单的静态链表以及单链表和双链表,它们各有优缺点,但是有个共同的问题是他们呢无法存储不同的数据.下面提供了一种方法,可以将不同节点的数据链接起来. 下面的代码都是基础的C ...
- 使用 InstructPix2Pix 对 Stable Diffusion 进行指令微调
本文主要探讨如何使用指令微调的方法教会 Stable Diffusion 按照指令 PS 图像.这样,我们 Stable Diffusion 就能听得懂人话,并根据要求对输入图像进行相应操作,如: 将 ...
- 2023-06-26:在大小为 n x n 的网格 grid 上,每个单元格都有一盏灯,最初灯都处于 关闭 状态 给你一个由灯的位置组成的二维数组 lamps 其中 lamps[i] = [rowi,
2023-06-26:在大小为 n x n 的网格 grid 上,每个单元格都有一盏灯,最初灯都处于 关闭 状态 给你一个由灯的位置组成的二维数组 lamps 其中 lamps[i] = [rowi, ...
- Java 文件写入不覆盖的写法
FileOutputStream o = null; File file = null; FileWriter fw = null; byte[] buff = new byte[]{}; try { ...
- 驱动开发:应用DeviceIoContro模板精讲
在笔者上一篇文章<驱动开发:应用DeviceIoContro开发模板>简单为大家介绍了如何使用DeviceIoContro模板快速创建一个驱动开发通信案例,但是该案例过于简单也无法独立加载 ...
- 技术选型|K歌App中的实时合唱如何进行选型
摘要 在线K歌软件的开发有许多技术难点,需考虑到音频录制和处理.实时音频传输和同步.音频压缩和解压缩.设备兼容性问题等技术难点外,此外,开发者还应关注音乐版权问题,确保开发的应用合规合法. 前言 前面 ...
- 响应式编程:Vert.x官网学习
本文基于 Vert.x 官网 https://vertx.io/ 内容,带领大家学习响应式编程里比较有名的工具包 Vert.x .文章内容取自官网由博主简化总结,希望帮助大家理解响应式编程. Vert ...
- Flutter upgrade 卡死问题
使用 到本地的flutter sdk的目录下 $flutter upgrade --force 降低到指定版本 : $flutter version 1.22.4