TC Asia Competition

250PT不说了。很水得一题。

500PT

给定n(<=1e18),求最大的因子,且这个因子为完全平方,假设这个因子为x那么满足x*x*y = n, 一直枚举因子到n^(1/3)就可以了。

最后判断一下剩余的是不是完全平方。

1000PT

一个排列组合题,一个中心出发有k条路,路与路之间有且仅有中心这个交点。现在要建n个城市,编号1~n,使得中心有一个城市,每条路末端有一个城市,然后其余城市就放在各条路的中间。首先保证中心和末端处各建设1个城市,问

总共有多少种安排方式。两种安排方式不同,表示至少存在一个城市他的邻居集合不相同。邻居是指不需要穿过任何城市就能直接到达的。

分析:

首先容易知道,中心城市有k个邻居,位于路的末端的城市有且仅有一个邻居,其他城市必须有2个邻居

所以对这个题目对k值分情况考虑:

k <= 2和k<=1时,由于此时路径可连接起来看做一条直线,实际相当于给n个城市一个排列,而且首尾交换的排列只能算一个,所以答案是n!/2.

k>=3 时,首先选定中心城市,n种情况,然后选定末端城市C(n-1,k),接下来剩n-k-1个城市,要各自安放在k条路径上,而且是应该考虑安放顺序的,所以是将n-k-1分给k条道路,并且排列一下。n-1-k分给k条道路可以这样理解。在n-1-k个*******中插入k-1条木棍,变成这样**|*|***|**, 在n-1-k+k-1 = n-2中选择k-1根木棍的位置,最后就是(n-k-1)!*C(n-2,k-1),ans = n*C(n-1,k)*(n-k-1)!*C(n-2,k-1) = n!*(n-2)!/(k-1)!/(n-k-1)!/k!.

代码:

  1 //Template update date: 20140316
  2 #include <iostream>
  3 #include <sstream>
  4 #include <cstdio>
  5 #include <climits>
  6 #include <ctime>
  7 #include <cstring>
  8 #include <cstdlib>
  9 #include <string>
 10 #include <stack>
 11 #include <set>
 12 #include <map>
 13 #include <cmath>
 14 #include <vector>
 15 #include <queue>
 16 #include <algorithm>
 17 #define  esp 1e-6
 18 #define  pi acos(-1.0)
 19 #define  inf 0x0f0f0f0f
 20 #define  pb push_back
 21 #define  lson l, m, rt<<1
 22 #define  rson m+1, r, rt<<1|1
 23 #define  lowbit(x) (x&(-x))
 24 #define  mp(a, b) make_pair((a), (b))
 25 #define  in  freopen("solve_in.txt", "r", stdin);
 26 #define  out freopen("solve_out.txt", "w", stdout);
 27
 28 #define  bug puts("********))))))");
 29 #define  inout in out
 30
 31 #define  SET(a, v) memset(a, (v), sizeof(a))
 32 #define  READ(a, n) {REP(i, n) cin>>(a)[i];}
 33 #define  REP(i, n) for(int i = 0; i < (n); i++)
 34 #define  Rep(i, base, n) for(int i = base; i < n; i++)
 35 #define  REPS(s, i) for(int i = 0; s[i]; i++)
 36 #define  pf(x) ((x)*(x))
 37 #define  Log(a, b) (log((double)b)/log((double)a))
 38 #define Srand() srand((int)time(0))
 39 #define random(number) (rand()%number)
 40 #define random_range(a, b) (int)(((double)rand()/RAND_MAX)*(b-a) + a)
 41
 42 using namespace std;
 43
 44 typedef long long  LL;
 45 typedef unsigned long long ULL;
 46 typedef vector<int> VI;
 47 typedef pair<int,int> PII;
 48 typedef vector<PII> VII;
 49 typedef vector<PII, int> VIII;
 50 typedef VI:: iterator IT;
 51 typedef map<string, int> Mps;
 52 typedef map<int, int> Mpi;
 53 typedef map<int, PII> Mpii;
 54 typedef map<PII, int> Mpiii;
 55 const int maxn = 1024*1025+100;
 56 LL inv[maxn];
 57 const int M = 1000000007;
 58 class Byteland{
 59 public:
 60 LL powmod(LL a, LL b, LL M) {
 61     LL res = 1;
 62     while(b) {
 63         if(b&1) res = (res*a)%M;
 64         a =(a*a)%M;
 65         b >>= 1;
 66     }
 67     return res;
 68 }
 69
 70 void pre() {
 71     Rep(i, 1, maxn) {
 72         inv[i] = powmod(i, M-2, M);
 73     }
 74 }
 75 LL solve(LL n, LL k) {
 76     pre();
 77     LL ans = 1;
 78     if(k <= 2) {
 79         Rep(i, 1, n+1) {
 80             ans = (ans*i)%M;
 81         }
 82         ans = ans*powmod(2, M-2, M)%M;
 83     } else {
 84         Rep(i,1, n+1) {
 85             if(i <= k+1)
 86                 ans = (ans*(n-i+1))%M;
 87             if(i <= n-2)
 88                 ans = (ans*i)%M;
 89             if(i <= k)
 90                 ans = (ans*powmod(i, M-2, M))%M;
 91             if(i <= k-1)
 92                 ans = (ans*powmod(i, M-2, M))%M;
 93         }
 94     }
 95     return ans;
 96 }
 97     int CountDifferentMaps(int n, int k){
 98         return solve(n, k);
 99     }
100 };

TC Asia Competition,布布扣,bubuko.com

时间: 2024-10-18 08:12:54

TC Asia Competition的相关文章

Topcoder Asia Programming Competition

进了Room后发现都是灰的或者绿的,内心愉快啊~觉得今天可以好好cha了. 比赛中: 250pt : 好简单啊... 500pt :大数分解,这我有模板啊! 1000pt : 简单推了一个公式后去验证了下样例,好像是对的,那就简单了,用逆元求个组合数就好了啊. 交完了1000pt后,机房突然断电了.我RP好好哦, 奥, 还要cha人呢,然后就跑回寝室了. cha人: 随便跑了一个大素数去cha了两个人的500,然后因为爆int叉掉了我们房间的另一个人的1000,看了下Rank,我去#2啊,貌似可

2014 ACM/ICPC Asia Regional Guangzhou Online Wang Xifeng&#39;s Little Plot HDU5024

一道好枚举+模拟题目.转换思维视角 这道题是我做的,规模不大N<=100,以为正常DFS搜索,于是傻乎乎的写了起来.各种条件限制模拟过程 但仔细一分析发现对每个点进行全部八个方向的遍历100X100X100^8 .100X100个点,每个点在走的时候8中选择,TLE 于是改为另一个角度: 以符合要求的点为拐弯点,朝两个垂直的方向走,求出最远的距离.这样只要对每个点各个方向的长度知道,组合一下对应的就OK. 避免了每个点深搜. PS:搜索的时候x,y写反了,导致构图出现问题,以后用[dy][dx]

HDU 5014 Number Sequence(2014 ACM/ICPC Asia Regional Xi&#39;an Online) 题解

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5014 Number Sequence Problem Description There is a special number sequence which has n+1 integers. For each number in sequence, we have two rules: ● ai ∈ [0,n] ● ai ≠ aj( i ≠ j ) For sequence a and sequ

hdu6206 Apple 2017 ACM/ICPC Asia Regional Qingdao Online

地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=6206 题目: Apple Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submission(s): 530    Accepted Submission(s): 172 Problem Description Apple is Taotao's favouri

tc。数组的定义。

新手知识普及.大鸟飘过. . 数组是一堆变量的集合.数组是一批,具有相同属性的变量. 可以这样说,数组的成员就是变量. . 呼叫数组的成员,使用 数组名+[下标 ]. 例如: var arr=数组(3) arr[0] = 90 arr[1] = 91 arr[2] = 92 arr[3] = 93 // // 言术: 在tc中声明数组,可以不指定成员的个数. 你可以把它想象成动态的,要多少有多少,不用担心下标越界. 例如: var arr=数组() arr[0] = 90 arr[100] = 

2016 ACM/ICPC Asia Regional Shenyang Online 1007/HDU 5898 数位dp

odd-even number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submission(s): 388    Accepted Submission(s): 212 Problem Description For a number,if the length of continuous odd digits is even and the length

hdu 5868 2016 ACM/ICPC Asia Regional Dalian Online 1001 (burnside引理 polya定理)

Different Circle Permutation Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total Submission(s): 208    Accepted Submission(s): 101 Problem Description You may not know this but it's a fact that Xinghai Square is

CIKM Competition数据挖掘竞赛夺冠算法陈运文

CIKM Competition数据挖掘竞赛夺冠算法陈运文 背景 CIKM Cup(或者称为CIKM Competition)是ACM CIKM举办的国际数据挖掘竞赛的名称.CIKM全称是International Conference on Information and Knowledge Management,属于信息检索和数据挖掘领域的国际著名学术会议,由ACM SIGIR分会(ACM Special Interest Group on Information Retrieval)主办.

tc命令——Linux基于IP进行流量限速

主要参考(所有权利归原文作者所有): *http://www.cnblogs.com/endsock/archive/2011/12/09/2281519.html *http://blog.163.com/ninja_wk/blog/static/989155620084280154811/ *http://www.chinaunix.net/jh/4/16110.html 一.TC原理 Linux操作系统中的流量控制器TC(Traffic Control)用于Linux内核的流量控制,主要是