• 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 };
    View Code
  • 相关阅读:
    Java ConcurrentModificationException 异常分析与解决方案
    android studio 怎么做屏幕适配?
    java Class.getSimpleName() 的用法
    LeetCode——Remove Element
    用WidgeDuino创建一个SCADA(监控与数据採集)系统
    【Oracle】OCR的备份和恢复之导出导入
    Java大数类介绍
    POJ 1113 Wall 凸包
    OPENCV中滑动条的使用
    Android
  • 原文地址:https://www.cnblogs.com/rootial/p/3873849.html
Copyright © 2020-2023  润新知