CREC 2017
A:Assignment Algorithm
#include <bits/stdc++.h>
using namespace std;
char s[][];
int a[][],n,m,ans=,A,B,l=,r=,ls=,rs=;
int k[]={,,,,,,,,,,,};
map<int,int>v;
void init(){
v[]=;v[]=;
v[]=;v[]=;
v[]=;v[]=;
v[]=;v[]=;
}
int pos=,vis=;
struct node{
int val,dis,id;//座位数,记录过道距离,行号
bool operator<(const node &a) const{
return a.val==val?(a.dis==dis?a.id>id:a.dis>dis):a.val<val;
}
}e[],p[];
void check(int dep){
int inf=;
for(int i=;i<=;i++)
if(inf>k[i] && s[dep][i]=='-'){
A=dep;
B=i;
inf=k[i];
}
if(B!= && s[A][v[B]]=='-'){
if(B<){
if(ls>rs) B=v[B];
}else if(B>){
if(ls<rs) B=v[B];
}
}
}
int main(){
init();
scanf("%d%d",&n,&m);
for(int i=;i<=n+;i++){
ans=;
scanf("%s",s[i]+);
for(int j=;j<=;j++){
if(s[i][j]=='-')ans++;
else if(s[i][j]=='#'){
if(j<) ls++;
else if(j>) rs++;
}
}
if(i== || i==n/+){
e[l].val=ans;
e[l].dis=;
e[l++].id=i;
pos+=ans;
}
else{
p[r].val=ans;
p[r].dis=min(abs(-i),min(abs(n/+-i),abs(n+-i)));
p[r++].id=i;
vis+=ans;
}
}
for(int i=;i<pos;i++){
sort(e,e+l);
check(e[].id);
s[A][B]=(char)('a'+i);
e[].val--;
if(B<) ls++;
else if(B>) rs++;//飞机平衡
}
for(int i=pos;i<m;i++){
sort(p,p+r);
check(p[].id);
s[A][B]=(char)('a'+i);
p[].val--;
if(B<) ls++;
else if(B>) rs++;
}
for(int i=;i<=n+;i++)
printf("%s\n",s[i]+);
return ;
}
/*
2 17
...........
---.#--.---
...........
---.---.---
...........
6 26
...........
---.---.###
#-#.---.---
---.###.---
...........
---.###.---
#--.#-#.--#
#--.--#.#-#
...........
*/
F:Faulty Factorial
#include <bits/stdc++.h>
using namespace std;
#define ll long long
ll v[],n,p,r;
ll quick_pow(ll x,ll y,ll mod){
ll ans=;
while(y){
if(y&) ans=ans*x%mod;
y>>=;
x=x*x%mod;
}
return ans%mod;
}
void init(){
v[]=;
for(ll i=;i<=p;i++){
v[i]=(p-(p/i))*v[p%i]%p;
//ll re=quick_pow(i,p-2,p);
//v[i]=re;
}
}
int main(){
scanf("%lld%lld%lld",&n,&p,&r);
init();
/*for(int i=1;i<=100;i++){
if(v[i]==0) printf("1 ");
//if(m[i]==0) printf(" 1\n");
}*/
if(n>=*p){
if(r==){
printf("%lld 1\n",p);
}
else printf("-1 -1\n");
}
else if(n>=p && r){
ll ans=;
for(int i=;i<=n;i++){
if(i==p) continue;
ans=ans*i%p;
}
int ok=;
for(ll i=;i<p;i++){
if(((ans*i)%p)==r){
printf("%lld %lld\n",p,i);
ok=;
break;
}
}
if(!ok) printf("-1 -1\n");
}
else if(n>=p && !r){
int ok=;
for(int i=;i<=n;i++){
if(i!=p){
printf("%d 1\n",i);
ok=;
break;
}
}
if(!ok) printf("-1 -1\n");
}
else if(n<p){
ll ans=;
for(ll i=;i<=n;i++)
ans=ans*i%p;
int ok=;
for(ll i=;i<=n;i++){
ll q=ans*v[i]%p;
ll re=r*v[q]%p;
if(re<i && re>){
printf("%lld %lld\n",i,re);
ok=;
break;
}
}
if(!ok) printf("-1 -1\n");
}
return ;
}
H:Hidden Hierarchy
#include <bits/stdc++.h>
#include <set>
using namespace std;
#define maxn 50006
vector<int>v[maxn];
map<int,string>im;
map<string,int>mi;
set<string>ss[maxn];
int val[maxn],n,x,cnt,ans=;
int vis[maxn];
string s;
void dfs(int u){
for(int i=;i<v[u].size();i++){
dfs(v[u][i]);
val[u]+=val[v[u][i]];
}
}
void bfs(int u){
if(vis[u]) return;
int pos=,ok=;
for(int i=;i<v[u].size();i++){
if(!vis[v[u][i]]){
pos=max(pos,val[v[u][i]]);
ok=;
}
}
if(!ok) cout<<" "<<im[u]<<" "<<val[u]<<endl;
else if( ok && pos<x) cout<<"+ "<<im[u]<<" "<<val[u]<<endl;
else if(ok && pos>=x){
cout<<"-"<<" "<<im[u]<<" "<<val[u]<<endl;
for(set<string>::iterator it=ss[u].begin();it!=ss[u].end();it++)
bfs(mi[*it]);
}
return ;
}
int main(){
scanf("%d",&n);
for(int i=;i<n;i++){
cin>>s>>x;
mi[s]=++ans;
im[ans]=s;
val[ans]=x;
vis[ans]=;
string fro=s;
for(int j=s.size()-;j>=;j--){
if(s[j]=='/'){
string subs=s.substr(,j+);
if(!mi[subs]){
mi[subs]=++ans;
im[ans]=subs;
v[ans].push_back(ans-);
ss[ans].insert(fro);
fro=subs;
}else{
v[mi[subs]].push_back(ans);
ss[mi[subs]].insert(fro);
break;
}
}
}
}
scanf("%d",&x);
dfs(mi["/"]);
bfs(mi["/"]);
return ;
}
/*
2
/a/a/a 100
/b.txt 99
200
8
/b/test/in.a 100
/b/test/in.b 1
/c/test/in.a 100
/c/test/in.b 1
/c/test/pic/in.a.svg 10
/c/test/pic/in.b.svg 10
/a/test/in.a 99
/a/test/in.b 1
101
9
/sys/kernel/notes 100
/cerc/problem/a/testdata/in 1000000
/cerc/problem/a/testdata/out 8
/cerc/problem/a/luka.cc 500
/cerc/problem/a/zuza.cc 5000
/cerc/problem/b/testdata/in 15
/cerc/problem/b/testdata/out 4
/cerc/problem/b/kale.cc 100
/cerc/documents/rules.pdf 4000
10000
*/
J:Justified Jungle
#include <bits/stdc++.h>
using namespace std;
int f[],vis[];
int re[],pos=;
int n,x,y;
vector<int>v[];
int find(int x){
return f[x]=f[x]==x?x:find(f[x]);
}
int p[],fin[];
int dfs(int u){
vis[u]=;
int ans=;
for(int i=;i<v[u].size();i++){
int to=v[u][i];
if(vis[to]) continue;
int x=find(u);
int y=find(to);
int k;
if(x!=y){
k=++pos;
f[y]=x;
}
re[k]=dfs(to);
ans+=re[k];
re[k]=min(re[k],n-re[k]);
}
return ans;
}
int main(){
scanf("%d",&n);
for(int i=;i<=n;i++)
f[i]=i;
for(int i=;i<n;i++){
scanf("%d%d",&x,&y);
v[x].push_back(y);
v[y].push_back(x);
}
dfs();
int cou=;
for(int i=;i<=n/;i++){
if(n%i) continue;
int inf=;
for(int j=;j<n;j++){
if(!(re[j]%i)) inf++;
}
if(inf>=((n/i)-)) fin[cou++]=n/i-;
}
sort(fin,fin+cou);
for(int i=;i<cou;i++)
printf("%d%c",fin[i],i==cou-?'\n':' ');
return ;
}
CREC 2017的更多相关文章
- CI Weekly #10 | 2017 DevOps 趋势预测
2016 年的最后几个工作日,我们对 flow.ci Android & iOS 项目做了一些优化与修复: iOS 镜像 cocoapods 版本更新: fir iOS上传插件时间问题修复: ...
- 猖獗的假新闻:2017年1月1日起iOS的APP必须使用HTTPS
一.假新闻如此猖獗 刚才一位老同事 打电话问:我们公司还是用的HTTP,马上就到2017年了,提交AppStore会被拒绝,怎么办? 公司里已经有很多人问过这个问题,回答一下: HTTP还是可以正常提 ...
- iOS的ATS配置 - 2017年前ATS规定的适配
苹果规定 从2017年1月1日起,新提交的 app 不允许使用NSAllowsArbitraryLoads来绕过ATS(全称:App Transport Security)的限制. 以前为了能兼容ht ...
- 深入研究Visual studio 2017 RC新特性
在[Xamarin+Prism开发详解三:Visual studio 2017 RC初体验]中分享了Visual studio 2017RC的大致情况,同时也发现大家对新的Visual Studio很 ...
- Xamarin+Prism开发详解三:Visual studio 2017 RC初体验
Visual studio 2017 RC出来一段时间了,最近有时间就想安装试试,随带分享一下安装使用体验. 1,卸载visual studio 2015 虽然可以同时安装visual studio ...
- Microsoft Visual Studio 2017 for Mac Preview 下载+安装+案例Demo
目录: 0. 前言 1. 在线安装器 2. 安装VS 3. HelloWorld 4. ASP.NET MVC 5. 软件下载 6. 结尾 0. 前言: 工作原因,上下班背着我的雷神,一个月瘦了10斤 ...
- Create an offline installation of Visual Studio 2017 RC
Create an offline installation of Visual Studio 2017 RC 2016年12月7日 ...
- .NET Core 2.0版本预计于2017年春季发布
英文原文: NET Core 2.0 Planned for Spring 2017 微软项目经理 Immo Landwerth 公布了即将推出的 .NET Core 2.0 版本的细节,该版本预计于 ...
- 卡巴斯基2017激活教程_卡巴斯基2017用授权文件KEY激活的方法
原创:天诺时空 更新时间:2016-11-09 2016年9月7日,卡巴斯基2017版全新上市,卡巴斯基依旧为大家奉上满足您所有需求的安全软件产品,为不同年龄层.不同人群给予全方位保护,同时延续卡 ...
随机推荐
- 上传图片到PHP服务器
test_picture = function() { api.getPicture({ sourceType: 'library', encodingType: 'png', mediaValue: ...
- PHP SPL 文件处理(SplFileInfo和SplFileObject)
SplFileInfo用来获取文件详细信息.SplFileObject遍历.查找指定行.写入csv文件等内容 SplFileInfo用来获取文件详细信息: $file = new SplFileInf ...
- pandaboy Merry Christmas
- mysql出错ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)
其他的贴会教你 1.键盘上win+r 2.输入cmd 3.输入net start mysql 但是还是没用 你可以试试 1.右击开始菜单 2.点击windows PowerShell(i) 3.输入 ...
- python与图灵机器人交互(ITCHAT版本)
#!/usr/bin/env python#-*- coding:utf-8 -*- @Author : wujf @Time:2018/9/5 17:42import requestsimport ...
- Quoit Design (HDU 1007)平面的最近点对
题目大意:给定平面上的 n 个点,求距离最近的两个点的距离的一半. n <= 10^5. 晕乎乎的度过了一上午... 总之来学习下分治吧233 分治就是把大问题拆成小问题,然后根据对小问题处 ...
- HDU-6217 BBP Formula 脑洞
题目链接:https://cn.vjudge.net/problem/HDU-6217 题意 已知: \[ \pi = \sum_{k=0}^{\infty }\frac{1}{16^{k}}(\fr ...
- [剑指offer] 41. 数据流中的中位数 (大小堆,优先队列)
对于海量数据与数据流,用最大堆,最小堆来管理. class Solution { public: /* * 1.定义一个规则:保证左边(大顶堆)和右边(小顶堆)个数相差不大于1,且大顶堆的数值都小于等 ...
- PHP学习总结(9)——PHP入门篇之WAMPServer服务控制面板介绍
及MySQL数据库的整合软件包.免去了开发人员将时间花费在繁琐的配置环境过程,从而腾出更多精力去做开发.在windows下将Apache+PHP+Mysql 集成环境,拥有简单的图形和菜单安装和配置环 ...
- Spring自带字符编码过滤器
http://blog.csdn.net/youngage/article/details/51356821 http://blog.csdn.net/daelly/article/details/5 ...