NOI2013 Day1

向量内积

题目描述:两个\(d\)维向量\(A\)与\(B\)的内积为其相对应维度的权值的乘积和,现有\(n\)个\(d\)维向量 ,求是否存在两个向量的内积为\(k\)(\(k=2,3\))的倍数。

solution:

考虑\(k=2\),以下为在\((mod 2)\)下运算,设矩阵\(A_1,A_2\),

设矩阵\(P=A_1 * A_2\),若非对角线出现\(0\),则有一对内积为\(0\)

\(P\)对角线上的\(0\)要处理一下

设矩阵\(F\),令\(F_{ii}+P_{ii}=1\),其余为\(0\)

设矩阵\(G\)全为\(1\)

矩阵\(T=G-F-P\),问题转为求是否有一元素在\(T\)中为\(1\)

随机一\(n * 1\)矩阵\(X\),若\(L=T * X,L_{i,1}=1\),则\(T_i\)有一元素为\(1\)

\(L=T * X=G * X-F * X-A_1 * (A_2 * X)\)

第一部分\(O(n)\), 第二部分\(O(nd)\),第三部分\(O(nd)\)。

考虑\(k=3\),\((mod 3)=0,1,2\),因为\(1 * 1=1(mod 3),2 * 2=1(mod 3)\),所以将内积结果平方就可以了。

假设两个\(d\)维向量\(A,B\)

\((A * B)^2=(A_1B_1+A_2B_2+ \cdots +A_dB_d)(A_1B_1+A_2B_2+ \cdots +A_dB_d)\)

\(=(A_1A_1+A_1A_2+ \cdots +A_1A_d+A_2A_1+ \cdots +A_2A_d+ \cdots +A_dA_d)*(B_1B_1+B_1B_2+ \cdots +B_1B_d+B_2B_1+ \cdots +B_2B_d+ \cdots +B_dB_d)\)

所以只需要将\(d\)维扩展到\(d^2\)维即可, 以上操作均在\((mod 3)\)下运算,所以只要\(L\)有非零就可以了。

时间复杂度:\(O(nd^2)\)

东方非想天则Orz

树的计数

题目描述:给定一个 DFS 序和 BFS 序,求符合条件的有根树中,树的高度的平均值。

solution

这题有点求期望值的味道。

根据\(BFS\)序对\(DFS\)序重标号。\(pos[i]\)表示\(i\)在\(DFS\)的第几位,\(deep[i]\)为\(i\)的深度

for (int i=1; i<=n; ++i) w[BFS[i]]=i;
for (int i=1; i<=n; ++i) DFS[i]=w[DFS[i]];
for (int i=1; i<=n; ++i) pos[DFS[i]]=i;

约束条件:

1、\(1\)为根

2、对于\(BFS\)连续的一段\([L, R]\),如果它们在同一层,必有\(pos[L]<pos[L+1]<\cdots<pos[R]\)

3、对于\(DFS\)的相邻两个数\(d[i],d[i+1]\),必有\(deep[d[i+1]]\leq deep[d[i]]+1\)

设\(s[i]\),当\(s[i]=1\)时,\(i\)与\(i+1\)不在同一层,当\(s[i]=0\)时,可能在同一行也可能不在。

转化约束条件:

1、\(s[i]=1\)

2、若\(pos[i+1]<pos[i],s[i]=1\)

3、若\(DFS[i]<DFS[i+1]\),则\(\sum_{j=d[i]}^{d[i+1]-1} s[i]\leq1\)(若\(DFS[i]>DFS[i+1]\),从\(BFS\)得\(deep[d[i+1]]\leq deep[d[i]]\))

用打标记的方法来表示某一段的\(s[i]\)的值是否确定,不确定的\(s[i]\)可以取\(0,1\)对答案的贡献为\(0.5\)。

因为\(i+1\)可以是\(i\)的儿子或兄弟要满足一下条件:

1、\(i+1\)为儿子时,\(i\)为所在层的最后一个,当\(i+1\)做兄弟时,\(i+1\)为所在层最后一个

2、其它不在\(i\)子树或\(i+1\)子树的点的深度均不超过\(i\),否则\(BFS\)有误。

以\(i+1\)为根的子树方案数是一定的,做儿子还是做兄弟只是多\(1\)的影响,所以贡献为\(0.5\)



(蓝框内不能有点,红框方案相同,最左边错误)

#include <cstdio>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <ctime>
#include <algorithm>
#include <deque>
#include <queue>
#include <vector>
#include <map>
#include <complex>
using namespace std; const int maxn=int(2e5)+100;
typedef int arr[maxn]; int n;
arr DFS, BFS, w, x, mat, sum, pos;
double ans; void init()
{
scanf("%d", &n);
for (int i=1; i<=n; ++i) scanf("%d", &DFS[i]);
for (int i=1; i<=n; ++i) scanf("%d", &BFS[i]);
for (int i=1; i<=n; ++i) w[BFS[i]]=i;
for (int i=1; i<=n; ++i) DFS[i]=w[DFS[i]];
for (int i=1; i<=n; ++i) pos[DFS[i]]=i;
}
void solve()
{
x[1]=1;
//mat用来标记那一段是确定的
mat[1]++; mat[2]--;
for (int i=1; i<n; ++i)
if (pos[i]>pos[i+1])
{
x[i]=1;
mat[i]++; mat[i+1]--;
}
for (int i=1; i<=n; ++i) sum[i]=sum[i-1]+x[i];
for (int i=1; i<n; ++i)
if (DFS[i]<DFS[i+1])
{
if (sum[DFS[i+1]-1]-sum[DFS[i]-1])
{
mat[DFS[i]]++;
mat[DFS[i+1]]--;
}
}
for (int i=1, cnt=0; i<n; ++i)
{
cnt+=mat[i];
if (cnt) ans+=x[i];//cnt>0说明s[i]是确定的
else ans+=0.5;
}
}
int main()
{
freopen("count.in", "r", stdin);
freopen("count.out", "w", stdout);
init();
solve();
printf("%.3lf\n", ans+1.0);
return 0;
}

时间复杂度:\(O(n)\)

NOI2013 Day1的更多相关文章

  1. NOIp2016 Day1&Day2 解题报告

    Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...

  2. day1

    day1.py ][][: ][: ): : ]['lock'] = 0 json.dump(userlist_message, open(userlist, 'w')) break #输错次数到3次 ...

  3. day1作业--登录入口

    作业概述: 编写一个登录入口,实现如下功能: (1)输入用户名和密码 (2)认证成功后显示欢迎信息 (3)输错三次后锁定 流程图: readme: 1.程序配置文件: 黑名单文件blacklist.t ...

  4. luogu1003铺地毯[noip2011 提高组 Day1 T1]

    题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯按照编号从小到大的顺序平行于 ...

  5. Python学习路程day1

    变量起名: 变量名如果太长,推荐使用下划线来分开,让人看得清晰明白.例:nums_of_alex_girl=19 .或者是驼峰写法,即首字母大写.例:NumOfAlexGf=18 注意:不合法的变量起 ...

  6. 团队项目——站立会议 DAY1

    团队项目--站立会议 DAY1        团队成员介绍(5人):张靖颜.何玥.钟灵毓秀.赵莹.王梓萱        今日(2016/5/6)为站立会议的第一天,一起对团队项目进行讨论,并对每个人的 ...

  7. Day1 login

    使用流程: 1.程序启动后,显示欢迎信息,提示用户输入用户名: 2.判断用户是否存在,不存在则提示重新输入,或者关闭程序:客户存在则提示客户输入密码: 3.判断密码是否正确,如果不正确则提示用户重新输 ...

  8. contesthunter CH Round #64 - MFOI杯水题欢乐赛day1 solve

    http://www.contesthunter.org/contest/CH Round %2364 - MFOI杯水题欢乐赛 day1/Solve Solve CH Round #64 - MFO ...

  9. noip2011提高组day1+day2解题报告

    Day1 T1铺地毯https://www.luogu.org/problem/show?pid=1003 [题目分析] 全部读入以后从最后一个往前找,找到一个矩形的范围覆盖了这个点,那这个矩形就是最 ...

随机推荐

  1. Linux 终端颜色高亮

    昨天在改一些东西时,不小心将root下的一些配置文件删掉了.导致启动终端后,字完全一个颜色,没有区分.在网上找到的都是 改整体颜色的.但实际上这时应该搜Linux终端高亮才能找到解决办法.在这里再列出 ...

  2. JS基础如何理解对象

    这几天跟几个同事聊天发现他们对javascript什么时候该用new都不是很了解. 1.javascript的function什么时候该new什么时候不该new?我觉得主要的问题还是集中在javasc ...

  3. C++ 常用容器or数据结构

    queue 队列 参考 1.入队:如q.push(x):将x元素接到队列的末端: 2.出队:如q.pop() 弹出队列的第一个元素,并不会返回元素的值:T 3,访问队首元素:如q.front() 4, ...

  4. 为每个页面加上Session判断 转

    首先新建一个类,继承自System.Web.UI.Page,然后重写OnInit,如下:   using System; using System.Data; using System.Configu ...

  5. Cortex-M3和Cortex-M4 Fault异常应用之二 ----- Fault处理函数的实现

    在项目处于调试期间,Fault处理程序可能只是一个断点指令,调试器遇到这个指令后停止程序的运行.默认情况下,由于非硬Fault被禁能,所有发生的非Fault都会上访成硬Fault,因此只要在硬Faul ...

  6. CSS预处理器实践之Sass、Less比较

    什么是CSS预处理器? CSS可以让你做很多事情,但它毕竟是给浏览器认的东西,对开发者来说,Css缺乏很多特性,例如变量.常量以及一些编程语法,代码难易组织和维护.这时Css预处理器就应运而生了.Cs ...

  7. 解决svn: Cannot negotiate authentication mechanism错误问题

    解决svn: Cannot negotiate authentication mechanism错误问题 作者:wangzz 原文地址:http://blog.csdn.net/wzzvictory/ ...

  8. VC实现将对话框最小化到系统托盘

    1.minisysDlg.h头文件设置: 1)public: void setTray();//设置托盘    NOTIFYICONDATA nid;//NOTIFYICONDATA结构包含了系统用来 ...

  9. zip命令

    常用示例: (1)zip -r myfile.zip ./*    ----将当前目录下的所有文件和文件夹全部压缩成myfile.zip文件, -r表示递归压缩子目录下所有文件. (2)unzip - ...

  10. C4.5较ID3的改进

    1.ID3选择最大化Information Gain的属性进行划分   C4.5选择最大化Gain Ratio的属性进行划分 规避问题:ID3偏好将数据分为很多份的属性 解决:将划分后数据集的个数考虑 ...