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版全新上市,卡巴斯基依旧为大家奉上满足您所有需求的安全软件产品,为不同年龄层.不同人群给予全方位保护,同时延续卡 ...
随机推荐
- JS 封装一个求n~m的求和函数
var a = 0; cc(2,10); function cc(n,m){ for(var i =n;i<(m+1);i++){ a = a + ...
- a标记地址的几种用法
1.<a href="tel://号码"></a> 手机使用能自动拨打电话 //可以省略 2.<a href="mailto://邮箱&qu ...
- Win 10安装mysql以及常见问题总结
一.mysql免安装版本配置1.从官网下载安装包,解压后,在电脑属性环境变量的path中配置bin的路径 2.配置my.ini [mysql] # 设置mysql客户端默认字符集 default-ch ...
- mDNS 原理的简单理解
转自:http://www.binkery.com/post/318.html mDNS 原理的简单理解 mDNS multicast DNS , 使用5353端口. 在局域网内,你要通过一台主机和其 ...
- JavaScript 原型 原型链
一. 普通对象与函数对象 JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object .Function 是 JS 自带的函数对象.下面举例说明 var o1 = ...
- [网络流24题] 方格取数问题/骑士共存问题 (最大流->最大权闭合图)
洛谷传送门 LOJ传送门 和太空飞行计划问题一样,这依然是一道最大权闭合图问题 “骑士共存问题”是“方格取数问题”的弱化版,本题解不再赘述“骑士共存问题”的做法 分析题目,如果我们能把所有方格的数都给 ...
- PHP实现并发请求
后端服务开发中经常会有并发请求的需求,比如你需要获取10家供应商的带宽数据(每个都提供不同的url),然后返回一个整合后的数据,你会怎么做呢? 在PHP中,最直观的做法foreach遍历urls,并保 ...
- jsp js action之间传值
1.struts2 action如何向JSP的JS函数传值 action中定义变量 public class TestAction extends ActionSupport implements S ...
- [jQuery]ajax同步请求在方法内问题
在函数内写$.ajax() 的成功函数中return 的值,并没有return到外层方法返回至
- hdu 4888 2014多校第三场1002 Redraw Beautiful Drawings 网络流
思路:一開始以为是高斯消元什么的.想让队友搞,结果队友说不好搞,可能是网络流.我恍然,思路立刻就有了. 我们建一个二部图.左边是行,右边是列,建个源点与行建边,容量是该行的和.列与新建的汇点建边.容量 ...