A. H国的身份证号码I

dfs裸题。

时间复杂度\(O(n^k)\)。

#include <bits/stdc++.h>
#define FOR(i,a,b) for (int i=a; i<=b; ++i)
int ans[15], n, k; void dfs(int pos, int pre){
if (pos>n) {
FOR(i,1,n) printf("%d",ans[i]);
putchar('\n');
return ;
}
FOR(i,0,k) {
if (i*pre>k) break;
ans[pos]=i; dfs(pos+1,i);
}
}
int main()
{
scanf("%d%d",&n,&k);
FOR(i,1,k) ans[1]=i, dfs(2,i);
return 0;
}

B.合并子目录

以 \(/\)为分隔符,对所有的文件夹进行hash后存入map,给每个文件夹的hash值分配一个id。

以这些id和文件夹的从属关系建树,那么只要\(size[i]=1\)就表示这个文件夹i可以和它的子文件夹合并。

时间复杂度\(O(nlogn)\)。

#include <bits/stdc++.h>
#define FOR(i,a,b) for (int i=a; i<=b; ++i)
#define pb push_back
map<int,int>mp;
map<int,bool>mark;
int id;
string s[N];
vector<int> v[500000], g[500000]; int main ()
{
int n, len, hah, p, t;
cin>>n;
FOR(i,1,n) {
cin>>s[i];
len=s[i].length(); hah=0;
for (int j=1; j<len; ++j) {
hah=131*hah+s[i][j];
if (s[i][j]=='/') {
if (mp.find(hah)==mp.end()) {
mp[hah]=++id;
if ((t=v[i].size())) g[mp[v[i][t-1]]].pb(id);
}
v[i].pb(hah);
}
}
if ((t=v[i].size())) mark[v[i][t-1]]=true;
}
FOR(i,1,n) {
len=s[i].length(); p=0;
for (int j=1; j<len; ++j) {
if (s[i][j]=='/') {
if (p+1>=v[i].size()) break;
if (g[mp[v[i][p]]].size()==1 && mark.find(v[i][p])==mark.end()) s[i][j]='-';
++p;
}
}
}
FOR(i,1,n) cout<<s[i]<<endl;
return 0;
}

C.H国的身份证号码II

令\(dp[i][j]\)表示前i位且第i位的数字是j的方法数。

显然有

1.\(i>1\Rightarrow dp[i][j](j\leq K)=\sum (dp[i-1][k] \mid j\times k\leq K,k\leq K)\)。

2.\(i=1\Rightarrow dp[i][j](1\leq j\leq K)=1\)。

注意到这个dp方程可以用矩阵快速幂加速。

时间复杂度\(O(10^3logn)\)。

#include <bits/stdc++.h>
#define FOR(i,a,b) for (int i=a; i<=b; ++i)
typedef long long LL; struct Matrix{LL matrix[N][N];}a, sa, unit, kk;
LL n;
int k; Matrix Mul(Matrix a, Matrix b) //矩阵乘法(%MOD)
{
Matrix c;
FOR(i,0,9) FOR(j,0,9) {
c.matrix[i][j]=0;
FOR(l,0,9) c.matrix[i][j]+=(a.matrix[i][l]*b.matrix[l][j])%MOD;
c.matrix[i][j]%=MOD;
}
return c;
}
Matrix Cal(LL exp) //矩阵快速幂
{
Matrix p=a, q=unit;
if (exp==0) return q;
while (exp!=1) {
if (exp&1) exp--, q=Mul(p,q);
else exp>>=1, p=Mul(p,p);
}
return Mul(p,q);
}
void init(){
FOR(i,0,9) unit.matrix[i][i]=1;
FOR(i,1,min(k,9)) kk.matrix[0][i]=1;
FOR(j,0,min(k,9)) FOR(i,0,min(k,9)) if (i*j<=k) a.matrix[i][j]=1;
}
int main ()
{
LL ans=0;
scanf("%lld%d",&n,&k);
init();
sa=Cal(n-1); sa=Mul(kk,sa);
FOR(i,0,9) ans=(ans+sa.matrix[0][i])%MOD;
printf("%lld\n",ans);
return 0;
}

D.观光旅行

图的最小生成树有一个性质,图的最小生成树上任意两点\((u,v)\)路径里的边的最大值是原图里\((u,v)\)路径里边的最大值最小的边。

由于题意中边权各不相同,所以最小生成树必定唯一。

因此对于那些不在最小生成树上的边,答案就是\((0,0)\)。

现在的问题是,对于出现在最小生成树的每一条边\((u,v)\),找出一条路径\((a,b)\),使得边\((u,v)\)出现在路径\((a,b)\)上,且是路径上的边权最大值。要求\(a<b\)且a尽量大b尽量小。

考虑边\((u,v)\)了,那么a必然是与u左边的一些点,b必然是与v右边的一些点。并且这两边的点分别构成了一个集合,使得集合内的边权都小于\(w(u,v)\)。

于是可以考虑按边权从小到大的方式枚举,用并查集维护点之间的连通性。

由于最后的答案还有要求,我们还需要对每个点集维护一个set来查询集合内id最大值,以及集合内第一个大于x的id。

然而或许还是会TLE,因为过程中需要合并set,考虑set的启发式合并,每次将size小的set并入size大的set内。

这些都可以在Kruskal的过程中完成。

时间复杂度\(O(nlog^2n)\)。

#include <bits/stdc++.h>
#define FOR(i,a,b) for (int i=a; i<=b; ++i)
typedef long long LL; int n, m;
struct Node{int u, v, w, id;}node[N<<1];
int F[N], ans[N<<1][2];
int ma[N], tmp[N];
set<int> a[N];
set<int>::iterator it; bool comp(Node a, Node b){return a.w<b.w;}
int find(int x){return F[x]==0?x:(F[x]=find(F[x]));}
void GB(int x, int y){
for (it=a[x].begin(); it!=a[x].end(); ++it) a[y].insert(*it);
}
void Prim(){
sort(node+1,node+m+1,comp);
FOR(i,1,m) {
int u=find(node[i].u), v=find(node[i].v);
if (u==v) continue;
if (ma[u]>ma[v]) {
ans[node[i].id][0]=ma[v], ans[node[i].id][1]=*a[u].lower_bound(ma[v]);
}
else {
ans[node[i].id][0]=ma[u], ans[node[i].id][1]=*a[v].lower_bound(ma[u]);
}
if (a[u].size()>a[v].size()) swap(u,v);
ma[v]=max(ma[u],ma[v]); GB(u,v);
F[u]=v;
}
}
int main ()
{
scanf("%d%d",&n,&m);
FOR(i,1,m) scanf("%d%d%d",&node[i].u,&node[i].v,&node[i].w), node[i].id=i;
FOR(i,1,n) a[i].insert(i), ma[i]=i;
Prim();
FOR(i,1,m) printf("%d %d\n",ans[i][0],ans[i][1]);
return 0;
}

[Offer收割]编程练习赛23-freeloop的更多相关文章

  1. hihocoder [Offer收割]编程练习赛4

    描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...

  2. hihocoder [Offer收割]编程练习赛61

    [Offer收割]编程练习赛61 A:最小排列 给定一个长度为m的序列b[1..m],再给定一个n,求一个字典序最小的1~n的排列A,使得b是A的子序列. 贪心即可,b是A的子序列,把不在b中的元素, ...

  3. [Offer收割]编程练习赛46

    [Offer收割]编程练习赛46赛后题解 A.AEIOU 分析

  4. [Offer收割]编程练习赛97

    链接 [https://hihocoder.com/contest/offers97/problems] 题意 题目1 : 放置矩形 时间限制:10000ms 单点时限:1000ms 内存限制:256 ...

  5. [Offer收割]编程练习赛9,10

    题目1 : 闰秒 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 计算机系统中使用的UTC时间基于原子钟,这种计时方式同“地球自转一周是24小时”的计时方式有微小的偏差. ...

  6. ACM学习历程—Hihocoder [Offer收割]编程练习赛1

    比赛链接:http://hihocoder.com/contest/hihointerview3/problem/1 大概有一个月没怎么打算法了.这一场的前一场BC,也打的不是很好.本来Div1的A和 ...

  7. HihoCoder1670 : 比赛日程安排([Offer收割]编程练习赛41)(模拟)

    描述 H国编程联赛中有N只队伍,编号1~N. 他们计划在2018年一共进行M场一(队)对一(队)的比赛. 为了让参赛队员能得到充分的休息,联赛组委会决定:每支队伍连续两场比赛之间至少间隔一天.也就是如 ...

  8. HihoCoder1655 : 第K小最简真分数([Offer收割]编程练习赛39)(唯一分解+容斥定理+二分)(不错的数学题)

    描述 给一个整数N,请你求出以N为分母的最简(既约)真分数中第K小的是多少? 输入 两个整数N个K. 对于30%的数据,1 <= N <= 1000000 对于100%的数据,1 < ...

  9. [Offer收割]编程练习赛48

    题目1 : 折线中点 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定平面上N个点P1, P2, ... PN,将他们按顺序连起来,形成一条折线. 请你求出这条折线的 ...

  10. [Offer收割]编程练习赛3 - 题目3 : 智力竞赛

    智力竞赛 Problem's Link ---------------------------------------------------------------------------- Mea ...

随机推荐

  1. DIV样式汇总

    DIV样式汇总 最近在学习JavaScript,在做到个要控制控件样式的例子时,突然有了把常用样式汇总一下的想法,于是乎就写了以下内容,以下是以div为例来汇总的,希望对大家有些帮助. 一.常用属性: ...

  2. Java+Netty实现的RESTful框架--netty-rest-server

    在工作中用Netty做了几个服务,感觉Netty做出来的程序性能好,资源占用少,但是实现Http服务比较麻烦,于是就参考Spring MVC的注解基于Netty实现了一个轻量级的RESTful框架. ...

  3. Myeclipse提高运行速度的方法

    下文是在其他博客拷过来的,借鉴借鉴,留个笔记,哈哈 1.老是弹出Quick update error .关闭myeclipse的Quick Update自动更新功能这个问题的解决办法是关闭自动更新Wi ...

  4. Docker--Dockerfile引用及指令集的功能用法

    Dockerfile引用的官网文档:https://docs.docker.com/engine/reference/builder/ 编写Dockerfiles的最佳实践的官网文档:https:// ...

  5. 在HTML中引用JavaScript中的变量

    和上次的代码几乎一样,但这次是引用已经写好的变量.主要功能和用法如下: document对象的getElementId方法得到HTML元素. HTML元素的value属性可以用来设置变量的值. 02. ...

  6. Linux 文件系统 -- 文件权限简介

    一.文件权限 使用 ls -l 命令可以查看文件的具体属性: 如图所示,第一列所示告诉了用户一个文件的类型和权限信息: 1)第一个字符 "d",表明该文件是一个目录文件: 2)r ...

  7. 基于Neutron的Kubernetes SDN实践经验之谈

    首先,向大家科普下Kubernetes所选择的CNI网络接口,简单介绍下网络实现的背景. CNI即Container Network Interface,是一套容器网络的定义规范,包括方法规范.参数规 ...

  8. JavaScript设计模式-----模板方法模式

    模板方法模式是一种只需要使用继承就可以实现的非常简单点的模式. 模板方法模式有两部分组成,第一部分是抽象父类,第二部分是具体的实现子类.通常在抽象父类中封装了子类的算法框架,包括实现 一些公共方法以及 ...

  9. roadhog中如何拷贝文件

    一:使用 public 目录 我们约定 public 目录下的文件会在 server 和 build 时被自动 copy 到输出目录(默认是 ./dist)下.所以可以在这里存放 favicon, i ...

  10. 一个基于NodeJS开发的APP管理CMS系统

    花了大概3周独立开发了一个基于NodeJS的CMS系统,用于公司APP的内容管理( **公司APP?广告放在最后 ^_^ ** ,管理员请理解~~~ )晚上看了部电影还不想睡,闲着也是闲着就作下小小总 ...