CF # 369 D2 D、E
D,只要抓住每个点只有一个出度,那么图就能分成几个部分,而且可以发现,一个部分最多一个环。
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring> using namespace std;
#define LL long long
const int MAXN = 200005;
const int MOD = 1e9 + 7;
int nt[MAXN]; int two[MAXN];
int part[MAXN];
int visit[MAXN];
int acyc[MAXN], acyn[MAXN]; int n, cyc, cyn; void dfs2(int u){
visit[u] = 3;
acyc[cyc] ++;
if(visit[nt[u]] == 3) return ;
dfs2(nt[u]);
} void dfs(int u){ visit[u] = 2;
if(visit[nt[u]] == 0){
dfs(nt[u]);
}
else if(visit[nt[u]] == 1){
cyn = part[nt[u]];
// visit[nt[u]] = 1;
}
else{
cyc ++;
cyn = cyc;
dfs2(nt[u]);
}
visit[u] = 1;
part[u] = cyn;
acyn[cyn]++;
} int main(){ two[0] = 1;
for(int i =1 ; i < MAXN; i++)
two[i] = (two[i - 1] * 2) % MOD; scanf("%d", &n);
memset(visit, 0, sizeof(visit));
memset(part, -1, sizeof(part));
for(int i = 1; i <= n; i++)
scanf("%d", &nt[i]); cyc = cyn = 0; for(int i = 1; i <= n; i++){
if(visit[i] == 0){
cyn = 0;
dfs(i);
}
} int ans = 1;
/*
for(int i = 1; i <= n; i++)
printf("%d ", part[i]);
puts(""); for(int i = 0; i <= cyc; i++){
printf("%d %d \n", acyc[i], acyn[i]);
}*/ for(int i = 0; i <= cyc; i++){
if(i == 0 && acyn[i] > 0){
ans = ((LL)ans * two[acyn[i] - 1])%MOD;
}
if(i > 0){
ans = (LL)ans * (two[acyn[i]] - (LL)2 * two[acyn[i] - acyc[i]]) % MOD;
}
}
if(ans < 0) ans = ((LL)ans + MOD) % MOD; printf("%d\n", ans); return 0;
}
E,题解在注释
/***************** 设 2^n = m ,分母为 m ^k ,算的分子为 m * (m - 1) *.... * (m - k + 1)
只要两个互质,最后用1减就是了,至于化简的过程,就是对分子提取因子2. 边界 太多,搞了一晚……不划算 ***********/ #include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring> using namespace std;
#define LL long long const int MOD =1000003; int mod[MOD + 5];
bool vis[MOD + 5]; LL tail[100]; int quick(int m, LL k){
int ret = 1;
int pow = m;
while(k){
if(k&1)
ret = (LL)ret * pow % MOD;
k >>= 1;
pow = (LL)pow * pow % MOD;
}
return ret;
} int cal(LL n, int index){ int m = quick(2, n);
int ret = 1;
int counts = 0; memset(vis, false, sizeof(vis)); for(LL i = 1; i <= tail[index]; i += 2){
if(vis[(((LL)m - i)%MOD + MOD)%MOD]){
break;
}
mod[counts++] = (((LL)m - i)%MOD + MOD) %MOD;
vis[mod[counts - 1]] = true;
} // cout << counts << endl; LL mc = tail[index] / 2 + 1;
LL cc = mc / counts; mc = mc % counts; for(int i = 0; i < counts; i++)
ret = ((LL)ret * mod[i]) % MOD; ret = quick(ret, cc);
for(int i = 0; i < mc; i++){
ret = ((LL)ret * mod[i]) %MOD;
} // cout <<"endl" << endl; return ret; } int main(){ LL n, k, tmp;
int counts = 0;
cin >> n >> k; double tt = log(k) / log(2) - n; if(n < 64){
if( tt > 1e-8){
cout << 1 << " " << 1 << endl;
return 0;
}
else if(tt < 1e-8){ LL ans = 1; for(LL i = 1; i <= n; i++)
ans = ans * 2; if(ans > 0 && ans < k){
cout << 1<< " "<< 1 << endl;
return 0;
} }
} tmp = k - 1; LL upc = 0; while(tmp){ if(tmp % 2 == 0){ upc += tmp / 2; tail[counts++] = tmp - 1;
tmp = tmp / 2;
}
else {
upc += tmp / 2;
tail[counts++] = tmp;
tmp = (tmp - 1) / 2;
} } // cout << upc << endl << endl; LL k_1 = k - 1 - upc; int down = quick(2, n - 1);
down = quick(down, k - 1);
down = (LL)down * quick(2, k_1) % MOD; int up = 1; // cout << down <<endl; // cout << "YES" << counts <<endl; for(int i = 0; i < counts; i++){
up = ((LL)up * cal(n - i, i))%MOD;
} up = ((down - up) % MOD + MOD) %MOD; cout << up <<" "<< down << endl;
}
CF # 369 D2 D、E的更多相关文章
- CF 369 B. Valera and Contest
http://codeforces.com/contest/369/problem/B 题意 :n, k, l, r, sall, sk,n代表的是n个人,这n个人的总分是sall,每个人的得分大于 ...
- CF#310 d2
A:|c[1]-c[0]| B:A+-(oc)A[0]==0..n-1 C: #include <cstdio> int n,m,i,j,k,p; int ll,ca,cb,cc; int ...
- CF# 368 D2 D
很容易想到可以它操作序列弄成有向图,果断深搜.但我开始竟然用了一种特醇的方法,每个书架做一次深搜,复杂度O(nq),跑到57个test就不动了.看看代码吧 #include <iostream& ...
- CF #330 D2 E
相当于给你一些点,要你最多删除不超过k,使得能使用一个边长为整数的长方形,与XY轴平行,使长方形的面积最小. 上课时拿笔来画画,然后忽然思路就开了,要是比赛也这样就好了~~先按X,Y分别排序,由于K较 ...
- CF #327 DIV2 D、E
两题都不难. 对于D题,可以使用相对移动,把吹aircraft移动变成相反方向的待援点的移动.假设此时时间为t,把aircraft的速度设为Vmax,看待援点在飞船最大速度飞行t秒的范围内,注意风向变 ...
- [nRF51822] 10、基础实验代码解析大全 · 实验15 - RTC
一.实验内容: 配置NRF51822 的RTC0 的TICK 频率为8Hz,COMPARE0 匹配事件触发周期为3 秒,并使能了TICK 和COMPARE0 中断. TICK 中断中驱动指示灯D1 翻 ...
- C、C++、Java、go的语法区别
详细C++.Java比较:http://www.cnblogs.com/stephen-liu74/archive/2011/07/27/2118660.html 一.C.C++的区别 在很大程度上, ...
- CF卡技术详解——笔记
知识太全面了,摘抄摘不完,还是粘过来加上注释和笔记吧. 重点以及断句用加粗,注释用红括号. 一.CF卡技术及规格 一.CF卡技术及规格 1.CF卡简史 随着数码产品的高速普及,近年来闪存卡也进入了高速 ...
- 你会用::before、::after吗
::before和::after伪元素的用法 一.介绍 css3为了区分伪类和伪元素,伪元素采用双冒号写法. 常见伪类——:hover,:link,:active,:target,:not(),:fo ...
随机推荐
- Android 计算view 的高度
上午在做一个QuickAction里嵌套一个ListView,在Demo运行没事,结果引入到我的项目里,发现我先让它在Button上面,结果是无视那个Button的高度,这很明显,就是那个Button ...
- HDU_1542_(树状数组)
Stars Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- hystrix 解决服务雪崩效应
1.服务雪崩效应 默认情况下tomcat只有一个线程池去处理客户端发送的所有服务请求,这样的话在高并发情况下,如果客户端所有的请求堆积到同一个服务接口上, 就会产生tomcat的所有线程去处理该服务接 ...
- 08CSS边框边距
CSS边框边距 边框样式——border-style border-top-style border-bottom-style border-left-style border-right-style ...
- vim 删除单个单词,cc和dd关系
c 功能和d相同,区别在于完成删除操作后进入INSERT MODE cc 也是删除当前行,然后进入INSERT MODE 删除每行第一个字符 :%s/^.//g ...
- POJ 1664 放苹果( 递推关系 )
链接:传送门 思路:苹果m个,盘子n个.假设 f ( m , n ) 代表 m 个苹果,n个盘子有 f ( m , n ) 种放法. 根据 n 和 m 的关系可以进一步分析: 特殊的 n = 1 || ...
- BZOJ3545 Peaks 离线处理+线段树合并
题意: 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问询问从点v开始只经 ...
- git命令初级
git是开源的分布式版本控制系统,分布式主要区别于集中式代表CVS(Concurrent Version System,遵从C/S架构,同步比较笨拙.)和SVN(Subversion),linux开发 ...
- HDU - 2102 A计划(双层BFS)
题目: 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验.魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长生不老.年迈的国王正是心急如焚, ...
- SQL中带有NOT IN 子查询改写
报表程序中的一段SQL运行很慢,代码如下: 优化前: 耗时:1337s INSERT INTO PER_LTE_ZIB_PB_COMMISSION_07 SELECT P.TOPACTUALID, Q ...