FR #1题解
A.
建图跑最小费用最大流。分类讨论每种情况如何连边,费用怎么定。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define maxv 105
#define maxe 100500
#define inf 1000000000
using namespace std;
int n,m,a[maxv],b[maxv],c[maxv],d[maxv],s,t,fin[maxv],fout[maxv],g[maxv],dis[maxv],nume=,ans=,pree[maxv],prev[maxv];
bool vis[maxv];
queue <int> q;
struct edge
{
int v,f,c,nxt;
}e[maxe];
void addedge(int u,int v,int f,int c)
{
e[++nume].v=v;e[nume].nxt=g[u];
e[nume].f=f;e[nume].c=c;g[u]=nume;
e[++nume].v=u;e[nume].nxt=g[v];
e[nume].f=;e[nume].c=-c;g[v]=nume;
}
bool spfa()
{
for (int i=s;i<=t;i++) {vis[i]=false;dis[i]=inf;}
dis[s]=;q.push(s);
while (!q.empty())
{
int head=q.front();q.pop();
for (int i=g[head];i;i=e[i].nxt)
{
int v=e[i].v;
if ((e[i].f) && (dis[v]>dis[head]+e[i].c))
{
dis[v]=dis[head]+e[i].c;
pree[v]=i;prev[v]=head;
if (!vis[v]) {vis[v]=true;q.push(v);}
}
}
vis[head]=false;
}
if (dis[t]==inf) return false;
return true;
}
int dinic()
{
int u=t,dt=inf;
while (u!=s)
{
dt=min(dt,e[pree[u]].f);
u=prev[u];
}
u=t;
while (u!=s)
{
e[pree[u]].f-=dt;
e[pree[u]^].f+=dt;
u=prev[u];
}
return dis[t]*dt;
}
int main()
{
scanf("%d%d",&n,&m);s=;t=n+;
for (int i=;i<=m;i++)
{
scanf("%d%d%d%d",&a[i],&b[i],&c[i],&d[i]);
fout[a[i]]+=d[i];fin[b[i]]+=d[i];
}
for (int i=;i<=n;i++)
{
if (fin[i]>fout[i]) addedge(s,i,fin[i]-fout[i],);
else addedge(i,t,fout[i]-fin[i],);
}
addedge(n,,inf,);
for (int i=;i<=m;i++)
{
if (d[i]>c[i])
{
addedge(a[i],b[i],inf,);
addedge(b[i],a[i],d[i]-c[i],);
addedge(b[i],a[i],c[i],);
ans+=d[i]-c[i];
}
else
{
addedge(a[i],b[i],c[i]-d[i],);
addedge(a[i],b[i],inf,);
addedge(b[i],a[i],d[i],);
}
}
while (spfa()) ans+=dinic();
printf("%d\n",ans);
return ;
}
B.
奇妙的数学题。
首先for i=2 -> n是肯定的。考虑如何在log^2n的时间内得到答案。
有一个log^3n的做法是显然的。对于一个新的i,我们枚举它所有的质因数,加到一个数组里,那么这是我们的答案就是对于每个质因数的答案和上一个的答案取max(每一个质因数的答案:若2出现i次,则找到2出现次数大于i次的最小的那个n)。然后我们二分答案,通过[n/p]+[n/p^2]+[n/p^3]+....算出答案。
考虑如何优化(神来之笔)。将n看成p进制的数akak-1ak-2....a1a0。然后考虑上面那个式子的答案就是Σai*(p^i-1)/(p-1),且使上面那个式子刚好>=cnt。怎么确定数组a呢?直接贪心就好了!预处理后面关于p的多项式,之后能取大就取大。这样一定是正确的(但是我不知道为什么)。。。。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 1000050
#define mod 1000000007
using namespace std;
long long n,k,prime[maxn/],tot=,mn[maxn],ans=,tab[maxn],kr=,num[maxn];
bool vis[maxn];
void get_table()
{
mn[]=;
for (long long i=;i<=maxn-;i++)
{
if (!vis[i]) {vis[i]=true;prime[++tot]=i;mn[i]=i;}
for (long long j=;j<=tot && i*prime[j]<=maxn-;j++)
{
vis[i*prime[j]]=true;mn[i*prime[j]]=prime[j];
if (!i%prime[j]) break;
}
}
}
long long ask(long long x,long long cnt)
{
if (x==-) return ;
long long lim=,ret=,ans=;tab[]=;
while (tab[ret]<=cnt) tab[++ret]=tab[ret-]*x+1LL;
ret--;
for (long long i=ret;i>=;i--)
{
ans=ans*x+cnt/tab[i];
cnt%=tab[i];
}
return ans*x;
}
int main()
{
scanf("%lld%lld",&n,&k);
get_table();
for (long long i=;i<=n;i++)
{
long long x=i,ret1=-,cnt=,rr;
while (x!=)
{
if (mn[x]!=ret1) {ans=max(ans,ask(ret1,num[ret1]*k));ret1=mn[x];}
num[mn[x]]++;
rr=mn[x];x/=mn[x];
}
ans=max(ans,ask(ret1,num[rr]*k));cnt=;
kr=(kr+ans)%mod;
}
printf("%lld\n",kr);
return ;
}
C.
杜教筛神题。。。感觉先要学一学杜教筛的东西再来看。就没写啦。
FR #1题解的更多相关文章
- FR #3题解
A. 傻逼题?...前缀和什么的随便搞搞就好了. #include<iostream> #include<cstdio> #include<cstring> #in ...
- FR #2题解
A. 考虑把(u,v)的询问离线挂在u上,然后dfs,每次从fath[x]到[x]相当于x子树dis区间加1,x子树以外区间-1,然后维护区间和区间平方和等. 常数略大. #include<io ...
- SDOI2017 Round2 详细题解
这套题实在是太神仙了..做了我好久...好多题都是去搜题解才会的 TAT. 剩的那道题先咕着,如果省选没有退役就来填吧. 「SDOI2017」龙与地下城 题意 丢 \(Y\) 次骰子,骰子有 \(X\ ...
- THUSC2017 Day1题解
THUSC2017 Day1题解 巧克力 题目描述 "人生就像一盒巧克力,你永远不知道吃到的下一块是什么味道." 明明收到了一大块巧克力,里面有若干小块,排成n行m列.每一小块都有 ...
- Codeforces Round #545 Div1 题解
Codeforces Round #545 Div1 题解 来写题解啦QwQ 本来想上红的,结果没做出D.... A. Skyscrapers CF1137A 题意 给定一个\(n*m\)的网格,每个 ...
- HNOI2018简要题解
HNOI2018简要题解 D1T1 寻宝游戏 题意 某大学每年都会有一次 Mystery Hunt 的活动,玩家需要根据设置的线索解谜,找到宝藏的位置,前一年获胜的队伍可以获得这一年出题的机会. 作为 ...
- BJOI2018简要题解
BJOI2018简要题解 D1T1 二进制 题意 pupil 发现对于一个十进制数,无论怎么将其的数字重新排列,均不影响其是不是 \(3\) 的倍数.他想研究对于二进制,是否也有类似的性质. 于是他生 ...
- NOIP2014题解
NOIP2014题解 Day1 生活大爆炸版石头剪刀布 rps 简单模拟题,注意细节 #include<iostream> #include<cstdio> using nam ...
- NOIP2012题解
NOIP2012题解 Day1 Vigenère 密码 vigenere 直接模拟就好了,对于那张表找找规律就很短了. #include<iostream> #include<cst ...
随机推荐
- BliBli抢楼全攻略
B站抢楼是一个很好玩的事情,每当新番出新集时.总有很多人想能够在前排发表评论,但是因为人数众多,往往不能如愿,今天就教大家一个抢楼的好办法. 我们平时抢楼的整个流程是这样的: 1.在官方放出的新番更新 ...
- ERROR 1130: Host 'root@localhost' is not allowed to connect to MySQL server
连接mysql时遇到的错误. 原因:该用户没有权限连接访问mysql数据库 解决方法:网站上搜了好多,试了都没有用.最终在登陆的信息页面用root用户登陆时不输入root密码即可.
- 笔记9:winfrom的一些知识点(二)
一.新建,和删除文件夹 private void button4_Click(object sender, EventArgs e) { Directory.Delete(@"F:\&quo ...
- Runner站立会议之个人记录
备注: 为方便记录,此随笔每日更新(因会议在晚上开,所以将昨天今天改成了今天明天) 2016.4.19 站立会议 今天学习到了:文件创建,adt基本知识,分别在虚拟机和手机上运行软件 明天要:继续学 ...
- JavaScript实现数组转置
//数组转置 var arr=[[2,5,6,8],[8,5,6,9],[9,6,2,1]] ; var arrNew=[];//定义一个新数组 for(var i=0;i<arr[ ...
- 详细解读Jquery各Ajax函数
$.get(),$.post(),$.ajax(),$.getJSON() 一,$.get(url,[data],[callback]) 说明:url为请求地址,data为请求数据的列表,callba ...
- css——子代与后代选择器
一直都以为,子代选择器与后代选择器作用是一样的,都是选择一个元素下面的子元素,直到今天才明白: 1.子代选择器(用<连接):ul>li 子选择器仅仅选择ul包围的 子元素 中的 li元素, ...
- 【模板下载】innosetup 制作.net安装包的模板
NetworkComms网络通信框架序言 这个模板是在博客园和CodeProject上的代码修改而成的,感谢原作者 模板是2个 innosetup 制作.net 2.0 安装包的模板 innosetu ...
- GUID vs INT Debate【转】
http://blogs.msdn.com/b/sqlserverfaq/archive/2010/05/27/guid-vs-int-debate.aspx I recently read a bl ...
- php连接ftp的研究,自带ftp函数 | fsockopen | curl实现ftp的连接
持续更新中..............