BestCoder #58 div1
2015-10-08 19:14:54
总结:赛后补的一场。题目蛮有意思的。
A:DFS
思路:搜一下几个环然后判断一下即可。
#include <cstdio>
#include <ctime>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <map>
#include <set>
#include <stack>
#include <queue>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std; #define getmid(l,r) ((l) + ((r) - (l)) / 2)
#define MEM(a,b) memset(a,b,sizeof(a))
#define MP(a,b) make_pair(a,b)
#define PB push_back typedef long long ll;
typedef pair<int,int> pii;
const double eps = 1e-;
const int INF = ( << ) - ;
const int MAXN = ; int T;
int n,ans,cnt;
int A[MAXN],B[MAXN],pos[MAXN];
int vis[MAXN]; void Dfs(int p){
if(vis[p]) return;
cnt++;
vis[p] = ;
Dfs(pos[p]);
} int main(){
scanf("%d",&T);
while(T--){
MEM(vis,);
scanf("%d",&n);
for(int i = ; i <= n; ++i) scanf("%d",A + i);
for(int i = ; i <= n; ++i){
int a;
scanf("%d",&a);
B[A[i]] = a;
pos[a] = A[i];
}
ans = ;
for(int i = ; i <= n; ++i) if(vis[i] == ){
cnt = ;
Dfs(i);
if(cnt == ) ans++;
else ans += cnt - ;
}
printf("%d\n",ans);
}
return ;
}
B:DP
题意:给出n个数,算出所有子序列去掉连续相同数(只保留一个)后的总和。
思路:总的思路就是总数 - 重复的计数。我们可以枚举每个数,算出其贡献,比如对于第i个数vi。先算左边的数,可取可不取,但是与vi相同的数一定不取,方案数为L,同理算出右边的方案数(算右边时可以取与vi相同的数),那么贡献就是vi×L×R。
#include <cstdio>
#include <ctime>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <map>
#include <set>
#include <stack>
#include <queue>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std; #define getmid(l,r) ((l) + ((r) - (l)) / 2)
#define MEM(a,b) memset(a,b,sizeof(a))
#define MP(a,b) make_pair(a,b)
#define PB push_back typedef long long ll;
typedef pair<int,int> pii;
const double eps = 1e-;
const int INF = ( << ) - ;
const int MAXN = ;
const ll mod = 1e9 + ; int T;
int n,A[MAXN];
ll pw[MAXN],pre[MAXN],val[MAXN];
map<int,ll> S1; int main(){
pw[] = pre[] = ;
for(int i = ; i <= ; ++i){
pw[i] = pw[i - ] * 2LL % mod;
pre[i] = (pre[i - ] + pw[i]) % mod;
}
scanf("%d",&T);
while(T--){
S1.clear();
scanf("%d",&n);
for(int i = ; i <= n; ++i)
scanf("%d",A + i);
for(int i = ; i <= n; ++i){
if(i == ) val[i] = ;
else val[i] = ( + pre[i - ] - S1[A[i]]) % mod;
val[i] = (val[i] + mod) % mod;
S1[A[i]] += pw[i - ];
}
for(int i = n - ; i >= ; --i){
val[i] = (val[i] * ( + pre[n - i - ])) % mod;
}
ll ans = ;
for(int i = ; i <= n; ++i){
ans = (ans + A[i] * val[i] % mod) % mod;
}
printf("%lld\n",ans);
}
return ;
}
C:树状数组
题意:n个数删除连续的m个数,算出最小逆序数。
思路:用两个树状数组模拟一个删除框即可。
#include <cstdio>
#include <ctime>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <map>
#include <set>
#include <stack>
#include <queue>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std; #define getmid(l,r) ((l) + ((r) - (l)) / 2)
#define MEM(a,b) memset(a,b,sizeof(a))
#define MP(a,b) make_pair(a,b)
#define PB push_back typedef long long ll;
typedef pair<int,int> pii;
const double eps = 1e-;
const int INF = ( << ) - ;
const int MAXN = ; int T,n,m;
int A[MAXN],fk[][MAXN]; void Update(int id,int x,int d){
while(x <= n){
fk[id][x] += d;
x += x & (-x);
}
} int Getsum(int id,int x){
int res = ;
while(x){
res += fk[id][x];
x -= x & (-x);
}
return res;
} int main(){
scanf("%d",&T);
while(T--){
MEM(fk,);
scanf("%d%d",&n,&m);
for(int i = ; i <= n; ++i) scanf("%d",A + i);
ll inv = ;
for(int i = m + ; i <= n; ++i){
inv += (i - m - ) - Getsum(,A[i]);
Update(,A[i],);
}
ll ans = inv;
// fk0 : pre , fk1 : suf
for(int i = ; i + m <= n; ++i){
inv -= (i - ) - Getsum(,A[i + m]);
inv -= Getsum(,A[i + m] - );
Update(,A[i + m],-);
inv += (i - ) - Getsum(,A[i]);
inv += Getsum(,A[i] - );
Update(,A[i],);
ans = min(ans,inv);
}
printf("%lld\n",ans);
}
return ;
}
D:DP+矩阵快速幂+生成树计数
思路:q轮选出n-1条边(构成一棵树)的方案数为cnt。对于每个生成树,构成其的方案数都是cnt。用dp[i][j]表示i轮选了j种边的方案数,转移方程:dp[i][j] = dp[i - 1][j - 1] * (n - j) + dp[i - 1][j] * j 用矩阵快速幂算出cnt。下面就是生成树计数,算出生成树种类num,那么答案就是cnt × num。
#include <cstdio>
#include <ctime>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <map>
#include <set>
#include <stack>
#include <queue>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std; #define getmid(l,r) ((l) + ((r) - (l)) / 2)
#define MEM(a,b) memset(a,b,sizeof(a))
#define MP(a,b) make_pair(a,b)
#define PB push_back typedef long long ll;
typedef pair<int,int> pii;
const double eps = 1e-;
const int INF = ( << ) - ;
const int MAXN = ; int T,n,m,p,q,mod;
int D[MAXN][MAXN],G[MAXN][MAXN]; ll Det(int n){
ll A[MAXN][MAXN];
for(int i = ; i <= n; ++i)
for(int j = ; j <= n; ++j)
A[i][j] = D[i][j];
ll res = ;
for(int i = ; i <= n; ++i){
for(int j = i + ; j <= n; ++j){
while(A[j][i]){
ll t = A[i][i] / A[j][i];
for(int k = i; k <= n; ++k)
A[i][k] = (A[i][k] - A[j][k] * t) % mod;
for(int k = i; k <= n; ++k)
swap(A[i][k],A[j][k]);
res = -res;
}
}
if(!A[i][i]) return ;
res = res * A[i][i] % mod;
}
return (res + mod) % mod;
} struct Mx{
ll a[MAXN][MAXN];
void clear(){ MEM(a,); }
void stand(){ clear(); for(int i = ; i <= n; ++i) a[i][i] = ; }
Mx operator * (const Mx &b){
Mx c; c.clear();
for(int k = ; k <= n; ++k)
for(int i = ; i <= n; ++i)
for(int j = ; j <= n; ++j){
c.a[i][j] = (c.a[i][j] + a[i][k] * b.a[k][j]) % mod;
}
return c;
}
}; Mx t; Mx Q_pow(int v){
Mx res; res.stand();
while(v){
if(v & ) res = res * t;
t = t * t;
v >>= ;
}
return res;
} int main(){
scanf("%d",&T);
while(T--){
MEM(D,);
MEM(G,);
scanf("%d%d%d%d",&n,&m,&p,&q);
mod = p;
for(int i = ; i <= m; ++i){
int a,b;
scanf("%d%d",&a,&b);
D[a][a]++;
D[b][b]++;
G[a][b] = G[b][a] = ;
}
for(int i = ; i <= n; ++i)
for(int j = ; j <= n; ++j)
D[i][j] -= G[i][j];
ll val = Det(n - );
//structure Mx t
t.clear();
for(int i = ; i <= n; ++i){
t.a[i][i] = i;
t.a[i][i - ] = n - i;
}
Mx ans; ans.clear();
ans.a[][] = n - ;
ans = Q_pow(q - ) * ans;
printf("%lld\n",(val * ans.a[n - ][]) % mod);
}
return ;
}
BestCoder #58 div1的更多相关文章
- HDU 5496 - BestCoder Round #58 - Beauty of Sequence
题目链接 : http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=637&pid=1002 思路 : 考 ...
- Bestcoder HDU5059 Help him 字符串处理
Help him Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total S ...
- Bestcoder#5 1002
Bestcoder#5 1002 Poor MitsuiTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (J ...
- NXP恩智浦P87C51/52/54/58/591芯片解密单片机破解多少钱?
NXP恩智浦P87C51/52/54/58/591芯片解密单片机破解 芯片解密型号: P87C51x2.P87C52x2.P87C54x2.P87C58x2.P87C591 单片机解密 #####[ ...
- BestCoder Round #80 1002
HDU 5666 Segment 题意:给你条斜率为-1,常数项为q(q为质数)的直线,连接原点与直线上整数格点,问你在有多少个格点在形成的无数个三角形内,而不在线段上,结果对P取模. 思路:best ...
- android模仿58筛选下拉框(PopupWindow实现)
前言:前几天用58同城APP找房子的时候,看到筛选下拉框蛮不错的,然后也有很多朋友需要实现这个功能,于是从网上下载了一个demo,在他的基础上进行修改,花了几个小时对他的代码进行修改,重构,封装.把一 ...
- Bestcoder#5 1003
Bestcoder#5 1003 Poor RukawTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- BestCoder 2nd Anniversary
A题 Oracle http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=703&pid=1001 大数相加: ...
- Bestcoder Round #84
A题 Aaronson http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=718&pid=1001 感觉一 ...
随机推荐
- elasticsearch性能因素总结
一:硬件方面 在预算充足的情况下.特别是一些高并发业务的搜索.硬件层面占用整个elasticsearch性能空间很大比例. 1)内存: 单实例的情况下,尽量分配32G,排序和统计都是以及内存计算的 ...
- Angular2 组件与模板 -- 输入和输出属性
Input and Output properties 输入属性是一个带有@Input 装饰器的可设置属性,当它通过属性绑定的形式被绑定时,值会"流入"到这个属性. 输出属性是一个 ...
- 基于openssl的https服务配置
环境: CA服务器:192.168.1.121 WEB服务器: 192.168.1.107 一.在CA服务器上生成自签证书 1.生成根私钥 (umask 077;openssl genrsa -out ...
- HDU1080(DP)
我用的dp是n^3的, dp[i][j] 表示在s串的i个前和t串的j个前,s[i],t[j]为最末端的两个串得到的最大值. 状态转移方程为: 之前将s和t串最尾端添加'-' ;i<=n;i++ ...
- 一句css代码让网站变灰
<style> html{ -webkit-filter: grayscale(100%); -moz-filter: grayscale(100%); -ms-filter: grays ...
- Vue-cli 安装使用和理解
Vue 的 官方文档 提到 点开这个链接,跟着文档一步步直到: $ npm install -g vue-cli $ vue init webpack my-project $ cd my-proje ...
- 160322、Maven手动安装Oracle的jar包
oracle的jar包 收费所以不能通过配置pom.xml获得,可以通过以下方法在pom.xml中引用 在命令行窗口执行(注意更改路径): mvn install:install-file -Dgro ...
- Eclipse+ADT+Android SDK 搭建安卓开发环境(版权属于forever-z)
运行环境 windows 7或者10(64位); 为例eclipse-jee-neon-3-win32-x86_64: ADT-23.0.4 下载地址 安装JDK 这里可以参考关于安装JDK的教程,请 ...
- Python 名称空间与作用域、闭包与装饰器
Python 的名称 Python 的名称(Name)是对象的一个标识(Identifier).我们知道,在 Python 里面一切皆对象,名称就是用来引用对象的.说得有点玄乎,我们以例子说明. 例如 ...
- (转)聊聊Servlet、Struts1、Struts2以及SpringMvc中的线程安全
前言 很多初学者,甚至是工作1-3年的小伙伴们都可能弄不明白?servlet Struts1 Struts2 springmvc 哪些是单例,哪些是多例,哪些是线程安全? 在谈这个话题之前,我们先了解 ...