郑州Day6
今天考了毕姥爷的一套题,差点保龄
挺良心的一套题,至少我不用再搬一遍题面了
T1.B君的第一题
我为什么当时去写了一个树形\(dp\)还妄图\(A\)掉啊
这题保龄感觉舒爽
首先如果我们要求的是点联通块的期望个数的话,那就非常好求了,一个点周围的边就算全删掉,这个点也是一个联通块,又因为这是一个树,所以每删一条边就会新增加一个联通块
所以答案就是
\]
但是这道题求的是边联通块,删掉\(i\)条边之后可能并不会剩下\(i+1\)个联通块
于是考虑把那些多算的贡献减掉,发现一个点周围的所有边都被删除之后这个点就不会成为联通块了
于是对于每个点单独算一些贡献
\]
\(d_i\)表示\(i\)的度,即和\(i\)相连的边数
代码
#include<cstdio>
typedef long long LL;
const LL MOD=1000000007;
LL inv[100005];
int x,y,d[100005];
LL pw[100005];
int n;
int main()
{
LL now=1,ans=1;
scanf("%d",&n);
for( int i=1;i<n;i++) scanf("%d%d",&x,&y),d[x]++,d[y]++;
inv[1]=1;
for (int i=2;i<=n+1;i++) inv[i]=(MOD-MOD/i)*inv[MOD%i]%MOD;
for (int i=1;i<n;i++) {
now=((now*(n-i))%MOD*inv[i])%MOD;
ans=(ans+now*(i+1)%MOD)%MOD;
}
ans=ans*2ll;ans%=MOD;
pw[0]=1;
for(int i=1;i<=n;i++) pw[i]=pw[i-1]*2ll%MOD;
for(int i=1;i<=n;i++)
ans=(ans+MOD-pw[n-d[i]])%MOD;
printf("%lld\n",ans);
return 0;
}
T2.B君的第二题
还是不怎么会
但是当时并没有看出来这是一个查第\(k\)大的数据结构可以维护的东西,甚至想用树状数组加二分,想一想好像挺难写就弃疗了
正解是求出每一个元素是第几轮出去的,之后上一个基排
并没有看懂\(f[i]=f[i-i/k-1]+1\)这样的操作,先放上毕姥爷代码
#include <bits/stdc++.h>
using namespace std;
int t, n, k, p, mod = 1000000007;
int f[1000020];
int c[1000020];
int a[1000020];
bool isPrime(int x) {
if (x < 2) {
return false;
}
for (int i = 2; i * i <= x; i++) {
if (x % i == 0) {
return false;
}
}
return true;
}
int main() {
freopen("harbin.in", "r", stdin);
freopen("harbin.out", "w", stdout);
scanf("%d", &t);
for (int tt = 0; tt < t; tt++) {
scanf("%d%d", &n, &k);
p = n;
while (!isPrime(p)) {
p++;
}
for (int i = 0; i < n; i++) {
c[i] = 0;
}
for (int i = 0; i < n; i++) {
if (i % k == 0) {
f[i] = 0;
} else {
f[i] = f[i - i / k - 1] + 1;
}
c[f[i] + 1]++;
}
for (int i = 1; i <= n; i++) {
c[i] += c[i - 1];
}
for (int i = 0; i < n; i++) {
a[c[f[i]]++] = i;
}
int z = 0;
for (int i = n - 1; i >= 0; i--) {
z = ((long long)z * p + a[i]) % mod;
}
printf("%d\n", z);
}
return 0;
}
T2.B君的第三题
可能是最简单的题了,也是我唯一能\(A\)的题了
看到都互质这个要求,我们就想到分解质因数之后没有相同的质因数
发现\(a_i<=30\),于是我们只需要考虑\(2\)到\(53\)这些质数,因为把\(30\)变成\(60\)多的数显然不如直接改成\(1\)更划算
发现这也就是\(16\)个质数,于是我们可以考虑状压
\(dp[i][s]\)表示前\(i\)个数选择的质因数状态为\(s\)的最小花费,每次我们枚举这个数改成什么,预处理出这个数分解之后的状态和\(s\)不能有交集就可以转移
代码
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#define re register
#define maxn 105
#define inf 15000
#define min(a,b) ((a)<(b)?(a):(b))
inline int read()
{
char c=getchar();int x=0;while(c<'0'||c>'9') c=getchar();
while(c>='0'&&c<='9') x=(x<<3)+(x<<1)+c-48,c=getchar();return x;
}
const int p[]={0,2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71};
short dp[2][1024*128+1];
int a[maxn],val[maxn];
int n,o,M;
int main()
{
n=read();
for(re int i=1;i<=n;i++) a[i]=read();
std::sort(a+1,a+n+1);
o=0;
for(re int i=1;i<=16;i++) if(a[n]+n<=p[i]) {M=i;break;}
if(!M) M=16;
for(re int i=1;i<(1<<M);i++) dp[o][i]=inf;
for(re int i=1;i<=p[M];i++)
{
int now=0,t=i;
for(re int k=1;k<=M;k++)
{
while(t%p[k]==0) t/=p[k],now|=(1<<(k-1));
if(t==1) break;
}
val[i]=now;
}
for(re int i=1;i<=n;i++,o^=1)
{
for(re int k=0;k<(1<<M);k++) dp[o^1][k]=inf;
for(re int j=1;j<=p[M];j++)
{
int now=((1<<M)-1)^val[j],t=(a[i]>j?a[i]-j:j-a[i]);
for(re int k=now;k;k=(k-1)&now)
dp[o^1][k|val[j]]=min(dp[o^1][k|val[j]],dp[o][k]+t);
dp[o^1][val[j]]=min(dp[o^1][val[j]],dp[o][0]+t);
}
}
int ans=inf;
for(re int k=0;k<(1<<M);k++)
ans=min(dp[o][k],ans);
printf("%d\n",ans);
return 0;
}
郑州Day6的更多相关文章
- Python之路,Day6 - Python基础6
本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configpars ...
- day6
开发一个简单的python计算器 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568 ...
- 敏捷遇上UML-需求分析及软件设计最佳实践(郑州站 2014-6-7)
邀请函: 尊敬的阁下:我们将在郑州为您奉献高端知识大餐,当敏捷遇上UML,会发生怎样的化学作用呢?首席专家张老师将会为您分享需求分析及软件设计方面的最佳实践,帮助您掌握敏捷.UML及两者相结合的实 ...
- Python学习记录day6
title: Python学习记录day6 tags: python author: Chinge Yang date: 2016-12-03 --- Python学习记录day6 @(学习)[pyt ...
- 团队项目——站立会议DAY6
团队项目--站立会议 DAY6 团队成员介绍(5人):张靖颜.何玥.钟灵毓秀.赵莹.王梓萱 今日(2016/5/13),站立会议已进行了一周时间,大家将这一周所遇到的问题和 ...
- pytho day6 <正则表达式、常用模块、反射>
本节介绍: 一:正则表达式: 正则表达并不是python 独有的.在各个语言里都有该语法的介绍.正则表达是处理字符串的强大的处理工具.拥有自己的独特的 处理方法.和处理引擎.虽然性能没有python ...
- python笔记 - day6
python笔记 - day6 参考: http://www.cnblogs.com/wupeiqi/articles/5501365.html 大纲: 利用递归,实现阶乘: Python反射 pyt ...
- 30天,APP创业从0到1【7.11郑州站】
活动概况 时间:2015年07月11日13:30-16:30 地点:慧谷咖啡(郑州杨金路9号河南外包产业园天元W栋) 主办:APICloud.环信.河南中医药大学医药信息化实验室 网址:www.api ...
- python_way day6 反射,正则 模块(进度条,hash)
python_way day6 反射 正则 模块 sys,os,hashlib 一.模块: 1.sys & os: 我们在写项目的时候,经常遇到模块互相调用的情况,但是在不同的模块下我们通过什 ...
随机推荐
- 安装并配置hive
教程:http://www.bubuko.com/infodetail-2523113.html 安装好mysql,然后进入mysql: 创建hive用户: 给hive用户赋权: 创建hive数据库, ...
- jvm双亲委派模型
其实,双亲委派模型并不复杂.自定义类加载器也不难!随便从网上搜一下就能搜出一大把结果,然后copy一下就能用.但是,如果每次想自定义类加载器就必须搜一遍别人的文章,然后复制,这样显然不行.可是自定义类 ...
- django学习笔记——搭建博客网站
1. 配置环境,创建django工程 虚拟环境下建立Django工程,即创建一个包含python脚本文件和django配置文件的目录或者文件夹,其中manage.py是django的工程管理助手.(可 ...
- http statusCode(状态码) 200、300、400、500序列详解
201-206都表示服务器成功处理了请求的状态代码,说明网页可以正常访问.200(成功) 服务器已成功处理了请求.通常,这表示服务器提供了请求的网页.201(已创建) 请求成功且服务器已创建了新的资源 ...
- SpringBoot---开发的热部署
1.模板的热部署 在SpringBoot中,模板引擎的页面默认是开启缓存的: 如果修改了页面的内容,则刷新不到修改后的页面: 可以在application.properties中关闭模板引擎的缓存: ...
- mysql 流程函数
一 , 流程函数 函数 功能 if(value,t f) 如果value是真,返回t;否则返回f ifnull(value1,value2) 如果valve1不为空返回value1,否则返回value ...
- nginx 问题总结
1, 403错误 403是很常见的错误代码,一般就是未授权被禁止访问的意思. 可能的原因有两种:Nginx程序用户无权限访问web目录文件Nginx需要访问目录,但是autoindex选项被关闭 修复 ...
- JavaScript设计模式(二) - 单例模式
什么是单例模式? 单例模式从字面上的理解是不困难的,js上就是指只有一个对象实例. 为什么需要单例模式? 我们可以将一些成员变量封装在一个单例对象中,每次访问这些变量都只能从这个单例对象进行访问,这样 ...
- Oracle新手常遇到的问题
1.问题描述:尝试加载 Oracle 客户端库时引发 BadImageFormatException.如果在安装 32 位 Oracle 客户端组件的情况下以 64 位模式运行,将出现此问题. 解决方 ...
- 项目搭建系列之四:SpringMVC框架下使用UrlRewrite实现地址重写
简单记录一下UrlRewrite实现地址重写功能. 1.pom.xml 在pom.xml增加配置UrlRewrite jar <!-- URL Rewrite --> <depend ...