hdu 6033

 pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
#include <bitset>
#include <string>
#include <complex>
#define ll __int64
#define mod 1000000007
using namespace std;
int n;
int main()
{
int t=;
while(scanf("%d",&n)!=EOF){
printf("Case #%d: %d\n",++t,(int)(n*(log()/log())));
}
return ;
}

hdu 6034

 #pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
#include <bitset>
#include <string>
#include <complex>
#define ll long long
#define mod 1000000007
using namespace std;
int n;
char a[];
map<char,int>mp;
int num[][];
int ans[];
struct node
{
char what;
int maxn;
} N[];
bool cmp(struct node aa,struct node bb)
{
if(aa.maxn>bb.maxn)
return true;
else
{
if(aa.maxn==bb.maxn)
{
for(int j=aa.maxn-; j>=; j--)
{
if(num[aa.what-'a'][j]!=num[bb.what-'a'][j])
return num[aa.what-'a'][j]>num[bb.what-'a'][j];
}
}
}
return false;
}
int main()
{
int s=;
while(scanf("%d",&n)!=EOF)
{
mp.clear();
for(int i=; i<=; i++)
{
memset(num[i],,sizeof(num[i]));
N[i].what=i+'a';
N[i].maxn=;
ans[i]=-;
}
for(int i=; i<=n; i++)
{
scanf("%s",a);
int lena=strlen(a);
if(lena>)
mp[a[]]=;
for(int j=; j<lena; j++)
{
num[a[j]-'a'][lena--j]+=;
N[a[j]-'a'].maxn=max(N[a[j]-'a'].maxn,lena--j+);
}
}
for(int i=; i<=; i++)
{
ll be=;
for(int j=; j<N[i].maxn; j++)
{
ll ok=(be+num[i][j])%;
be=(be+num[i][j])/;
num[i][j]=ok;
}
int jishu=N[i].maxn;
while(be>)
{
num[i][jishu]=be%;
be/=;
jishu++;
}
N[i].maxn=jishu;
} sort(N,N+,cmp);
for(int i=; i>=; i--)
{
if(mp[N[i].what]==)
{
ans[i]=;
break;
}
}
int jishu=;
for(int i=; i<=; i++)
{
if(ans[i]==-)
{
ans[i]=jishu;
jishu--;
}
}
ll re=;
for(int i=; i<=; i++)
{
if(ans[i]!=)
{
ll gg=;
for(int j=; j<N[i].maxn; j++)
{
re=(re+gg*(num[N[i].what-'a'][j]*ans[i])%mod)%mod;
gg*=;
gg%=mod;
}
} }
cout<<"Case #"<<++s<<": "<<re<<endl;
}
return ;
}

hdu 6035

 #pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
#include <bitset>
#include <string>
#include <complex>
#define ll long long
#define mod 1000000007
using namespace std;
ll n;
ll pre[];
ll used[];
ll siz[];
ll sum[];
ll col[];
ll gg[];
struct node
{
ll to;;
ll pre;
} N[];
ll nedge=;
ll ans=;
void init()
{
for(int i=; i<=n; i++){
pre[i]=;
used[i]=;
gg[i]=;
sum[i]=;
siz[i]=;
col[i]=;
}
nedge=;
}
void add(ll st,ll ed)
{
nedge++;
N[nedge].to=ed;
N[nedge].pre=pre[st];
pre[st]=nedge;
}
void dfs(ll root)
{
used[root]=;
siz[root]=;
ll be=sum[col[root]];
ll ad=;
for(int i=pre[root]; i; i=N[i].pre)
{
if(used[N[i].to]==)
{
dfs(N[i].to);
siz[root]+=siz[N[i].to];
ll sonu=sum[col[root]]-be;
ll tmp=siz[N[i].to]-sonu;
ad+=sonu;
ans=ans-tmp*(tmp-)/;
be=sum[col[root]];
} }
sum[col[root]]+=(siz[root]-ad);
}
int main()
{
//freopen("input.txt","r",stdin);
//freopen("output.txt","w",stdout);
int t=;
while(scanf("%lld",&n)!=EOF)
{
init();
ll jishu=;
for(int i=; i<=n; i++){
scanf("%lld",&col[i]);
if(gg[col[i]]==){
jishu++;
gg[col[i]]=;
}
}
ll a,b;
for(int i=; i<n; i++)
{
scanf("%lld %lld",&a,&b);
add(a,b);
add(b,a);
}
ans=jishu*(n*(n-)/);
dfs();
for(int i=;i<=n;i++){
if(sum[i]!=){
ll res=n-sum[i];
ans=ans-(res-)*res/;
}
}
printf("Case #%d: %lld\n",++t,ans);
}
return ;
}

hdu 6038

 #pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
#include <bitset>
#include <string>
#include <complex>
#define ll long long
#define mod 1000000007
using namespace std;
int n,m;
int a[];
int b[];
vector<int> aa;
vector<int> bb;
map<int,int>mp;
int main()
{
int t=;
while(scanf("%d %d",&n,&m)!=EOF)
{
aa.clear();
bb.clear();
mp.clear();
for(int i=; i<n; i++)
scanf("%d",&a[i]);
for(int j=; j<m; j++)
scanf("%d",&b[j]);
for(int i=;i<n;i++)
{
if(mp[i]==)
{
int now=;
mp[i]=;
int s=i;
while(mp[a[s]]==){
now++;
mp[a[s]]=;
s=a[s];
}
aa.push_back(now);
}
}
mp.clear();
for(int i=;i<m;i++)
{
if(mp[i]==)
{
int now=;
mp[i]=;
int s=i;
while(mp[b[s]]==){
now++;
mp[b[s]]=;
s=b[s];
}
bb.push_back(now);
}
}
ll ans=;
for(int i=;i<aa.size();i++){
ll temp=;
for(int j=;j<bb.size();j++){ if(aa[i]%bb[j]==)
temp+=bb[j];
}
ans=(ans*temp)%mod;
}
printf("Case #%d: %lld\n",++t,ans);
}
return ;
}

hdu 6043

 #pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
#include <bitset>
#include <string>
#include <complex>
#define ll long long
#define mod 1000000007
using namespace std;
ll n,k;
int main()
{
int t=;
while(scanf("%lld %lld",&n,&k)!=EOF){
if(k<=n)
printf("Case #%d: %lld\n",++t,k);
else
{
ll now;
ll which;
now=(k-n)/(n-);
which=(k-n)%(n-);
if(now%==)
{
if(which==)
printf("Case #%d: %lld\n",++t,n);
else
printf("Case #%d: %lld\n",++t,which);
}
else
{
if(which==)
printf("Case #%d: %lld\n",++t,n-);
else
printf("Case #%d: %lld\n",++t,which);
}
}
}
return ;
}

2017 Multi-University Training Contest - 1的更多相关文章

  1. 2017 Wuhan University Programming Contest (Online Round) Lost in WHU 矩阵快速幂 一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开。

    /** 题目:Lost in WHU 链接:https://oj.ejq.me/problem/26 题意:一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开. ...

  2. 2017 Wuhan University Programming Contest (Online Round) C. Divide by Six 分析+模拟

    /** 题目:C. Divide by Six 链接:https://oj.ejq.me/problem/24 题意:给定一个数,这个数位数达到1e5,可能存在前导0.问为了使这个数是6的倍数,且没有 ...

  3. 2017 Wuhan University Programming Contest (Online Round) B Color 树形dp求染色方法数

    /** 题目:Color 链接:https://oj.ejq.me/problem/23 题意:给定一颗树,将树上的点最多染成m种颜色,有些节点不可以染成某些颜色.相邻节点颜色不同.求染色方法数. 思 ...

  4. 2017 Wuhan University Programming Contest (Online Round) D. Events,线段树区间更新+最值查询!

    D. Events 线段树区间更新查询区间历史最小值,看似很简单的题意写了两天才写出来. 题意:n个数,Q次操作,每次操作对一个区间[l,r]的数同时加上C,然后输出这段区间的历史最小值. 思路:在线 ...

  5. 2017 Multi-University Training Contest - Team 9 1005&&HDU 6165 FFF at Valentine【强联通缩点+拓扑排序】

    FFF at Valentine Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  6. 2017 Multi-University Training Contest - Team 9 1004&&HDU 6164 Dying Light【数学+模拟】

    Dying Light Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  7. 2017 Multi-University Training Contest - Team 9 1003&&HDU 6163 CSGO【计算几何】

    CSGO Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  8. 2017 Multi-University Training Contest - Team 9 1002&&HDU 6162 Ch’s gift【树链部分+线段树】

    Ch’s gift Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total S ...

  9. 2017 Multi-University Training Contest - Team 9 1001&&HDU 6161 Big binary tree【树形dp+hash】

    Big binary tree Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  10. 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】

    Colorful Tree Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

随机推荐

  1. SQL Server变量杂谈

    学习SQL的过程有进步的话还是一件很美妙的事情的 在第一家公司虽然只呆了两年,但是感觉是我进步最快的两年.那时候工作和生活都挺充实的,每天都有一点点的收获和付出,其中最大的收获莫过于掌握一些核心技能. ...

  2. Tensorflow - Implement for a Softmax Regression Model on MNIST.

    Coding according to TensorFlow 官方文档中文版 import tensorflow as tf from tensorflow.examples.tutorials.mn ...

  3. eclipse版本信息及操作系统

    一.查看版本信息: 进入到eclipse安装目录下,有一个.eclipseproduct文件,用记事本打开,就可以知道版本了,后面version=的值就是版本 二.是否为32位操作系统: 找到ecli ...

  4. Thunder——互评beta版本

    基于NABCD和spec评论作品 Hello World!:http://www.cnblogs.com/vector121/p/7922989.html 欢迎来怼:http://www.cnblog ...

  5. struts通配符*的使用

    <action name="user_*" class="com.wangcf.UserAction" method="{1}"> ...

  6. 随机生成四则运算式2-NEW+PSP项目计划(补充没有真分数的情况)

    PS:这是昨天编写的随机生成四则运算式2的代码:http://www.cnblogs.com/wsqJohn/p/5264448.html 做了一些改进. 补:在上一次的运行中并没有加入真分数参与的运 ...

  7. mysql 对表格加索引但原表格有重复数据

    1.把表中唯一数据搜索创建临时表,最后代替原先表. create table mmmmmm as SELECT * FROM meriadianannotation GROUP BY SeriesID ...

  8. POJ 2484(对称博弈)

    题目链接:http://poj.org/problem?id=2484 这道题目大意是这样的,有n个硬币围成一圈,两个人轮流开始取硬币(假设他们编号从1到n),可以选择取一枚或者取相邻的两枚(相邻是指 ...

  9. StringBuilder、StringBuffer和String三者的联系和区别

    String 类    String的值是不可变的,这就导致每次对String的操作都会生成新的String对象,不仅效率低下,而且大量浪费有限的内存空间.    String a = "a ...

  10. lintcode-65-两个排序数组的中位数

    65-两个排序数组的中位数 两个排序的数组A和B分别含有m和n个数,找到两个排序数组的中位数,要求时间复杂度应为O(log (m+n)). 样例 给出数组A = [1,2,3,4,5,6] B = [ ...