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. 238. [LeetCode] Product of Array Except Self

    Given an array nums of n integers where n > 1,  return an array output such that output[i] is equ ...

  2. hbase中balance机制

    HBase是一种支持自动负载均衡的分布式KV数据库,在开启balance的开关(balance_switch)后,HBase的HMaster进程会自动根据指定策略挑选出一些Region,并将这些Reg ...

  3. 面对30页左右的运放数据手册datasheet,你需要知道如何看懂

    1.输入失调电压(Input Offset Voltage) VOS    若将运放的两个输入端接地,理想运放输出为零,但实际运放输出不为零.此时,用输出电压除以增益得到的等效输入电压称为输入失调电压 ...

  4. vmvare fusion 8

    http://jingyan.baidu.com/article/54b6b9c0f8830f2d583b47ce.html 补充:vmware tools  在上面,直接点击安装

  5. C++Primer第五版——习题答案和解析

    感谢原文博主的分享:https://blog.csdn.net/misayaaaaa/article/details/53786215 新手入门必看的书.知识是一个系统化并且相互关联的体系,零散的东西 ...

  6. plsql 永久注册码

    注册码:Product Code:4t46t6vydkvsxekkvf3fjnpzy5wbuhphqzserial Number:601769 password:xs374ca 可用

  7. Web站点性能-微观手段

    文章:网站性能优化 百度百科:高性能Web站点 文章:构建高性能WEB站点之 吞吐率.吞吐量.TPS.性能测试

  8. TCP系列49—拥塞控制—12、DSACK下的拥塞撤销

    一.概述 DSACK下的虚假重传的检测我们之前重传部分的文章已经介绍过了,这里简单说一下拥塞控制部分的实现. linux内部会维护一个undo_retrans状态变量,其值为已经重传的次数减掉被DSA ...

  9. find . -name file -exec echo abc > {} \; fail

    find . -name file -exec echo abc > {} \; fail 应该改用: find . -name file -exec bash -c 'echo abc > ...

  10. QQueue与QStack使用

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QQueue与QStack使用     本文地址:http://techieliang.com ...