[NOIP2014] 普及组
模拟。
将所有“两个不同数之和”装进桶里,扫描原数组记录满足条件的数的个数。
/*by SilverN*/
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
const int mxn=;
int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int n;
int a[mxn];
int cnt[mxn];
int main(){
int i,j;
n=read();
for(i=;i<=n;i++){
a[i]=read();
}
for(i=;i<n;i++)
for(j=i+;j<=n;j++){
cnt[a[i]+a[j]]++;
}
int res=;
for(i=;i<=n;i++){
if(cnt[a[i]])res++;
}
cout<<res<<endl;
return ;
}
珠心算测验
暴力。
因为L<=100,所以分子和分母都从1循环到100,暴力判断即可。
/*by SilverN*/
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int gcd(int a,int b){
if(!b)return a;
return gcd(b,a%b);
}
int a,b,L;
int ra=,rb=;
int main(){
int i,j;
a=read();b=read();L=read();
for(i=;i<=L;i++)
for(j=;j<=L;j++){
if(gcd(i,j)!=)continue;
if(i*b>=j*a && i*rb<j*ra){
ra=i;
rb=j;
}
}
printf("%d %d\n",ra,rb);
return ;
}
比例简化
O(n^2)循环会超时。
可以计算出最外围一圈数的个数,每次拆掉一圈数,到了目标数所在的圈再暴力查找。
/*by SilverN*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<vector>
using namespace std;
int n;
int main(){
int i,j;
cin>>n>>i>>j;
long long ans=;
int eg=min(min(n-i,i-),min(n-j,j-));
for(int k=;k<eg;++k)ans+=(n-*k)*-;
i-=eg;j-=eg;n-=*eg;
if(i==)ans+=j;
else if(i==n)ans+=*(n-)+n-j+;
else if(j==)ans+=*(n-)+n-i+;
else if(j==n)ans+=n-+i;
printf("%d\n",ans);
return ;
}
螺旋矩阵
暴力DFS选择的行,然后在所选行上DP。
DP时需要前缀和优化。
/*by SilverN*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<vector>
using namespace std;
int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int f[][];
int n,m,r,c;
int mp[][];
int ans=1e9;
//bool vis[17];
int use[];
int ds[];//行之间的差值
int cs[][];//列之间的差值
void DP(){
memset(cs,,sizeof cs);
memset(ds,,sizeof ds);
memset(f,0x3f,sizeof f);
int i,j;
for(i=;i<m;i++)
for(j=i+;j<=m;j++){
for(int k=;k<=r;k++){
cs[i][j]+=abs(mp[use[k]][j]-mp[use[k]][i]);
}
}
for(i=;i<=m;i++)
for(j=;j<=r;j++){
ds[i]+=abs(mp[use[j]][i]-mp[use[j-]][i]);
}
//init
// for(i=1;i<=m;i++) //
memset(f[],,sizeof f[]);
for(i=;i<=c;i++){
for(j=i;j<=m;j++){
for(int k=;k<j;k++){
f[i][j]=min(f[i][j],f[i-][k]+cs[k][j]);
}
f[i][j]+=ds[j];
}
}
int res=1e9;
for(i=c;i<=m;i++)res=min(res,f[c][i]);
// printf("res:%d\n",res);
ans=min(ans,res);
// printf("%d\n",ans);
return;
} void DFS(int dep,int pos){
if(dep>r){
/* printf("use:");
for(int i=1;i<=r;i++)printf("%d ",use[i]);
printf("\n");*/
DP();return;
}
int lim=n-(r-dep);
for(int i=pos;i<=lim;i++){
use[dep]=i;
DFS(dep+,i+);
}
return;
}
int main(){
int i,j;
n=read();m=read();r=read();c=read();
for(i=;i<=n;i++)
for(j=;j<=m;j++)
mp[i][j]=read();
DFS(,);
// use[1]=4;use[2]=5;DP(); printf("%d\n",ans);
return ;
}
子矩阵
[NOIP2014] 普及组的更多相关文章
- 【NOIP2014 普及组】螺旋矩阵
[NOIP2014 普及组]螺旋矩阵 一.题目 [NOIP2014 普及组]螺旋矩阵 时间限制: 1 Sec 内存限制: 128 MB 提交: 18 解决: 0 [提交][状态][讨论版] 题目描 ...
- noip2014普及组——珠心算测验
题目描述 珠心算是一种通过在脑中模拟算盘变化来完成快速运算的一种计算技术.珠心算训练,既能够开发智力,又能够为日常生活带来很多便利,因而在很多学校得到普及. 某学校的珠心算老师采用一种快速考察珠 ...
- 螺旋矩阵 noip2014普及组
本题可以直接模拟填数字,也可以直接计算结果. 代码一:(这个代码,缺陷在于数组太大,浪费内存啊.另外,循环次数也不少.总之,时间空间的消耗都不小.) /*======================= ...
- noip2014普及组 比例简化
题目描述 在社交媒体上,经常会看到针对某一个观点同意与否的民意调查以及结果.例如,对某一观点表示支持的有1498 人,反对的有 902人,那么赞同与反对的比例可以简单的记为1498:902. 不过,如 ...
- [NOIP2014普及组]子矩阵
题目:洛谷P2258.Vijos P1914.codevs 3904. 题目大意:给你一个矩阵,要你找一个r行c列的子矩阵,求最小分值(子矩阵和分值的定义见原题). 解题思路:n和m比较小,考虑暴力. ...
- [NOIP2014普及组T1]珠心算测验 - NTT
求数组有多少个数,恰好等于集合中另外两个(不同的)数之和? 注意到数集比较小,而且涉及到下标的加法,可以很自然地想到卷积 注意减去自己加自己的贡献 真是一道NTT练手好题 #include <i ...
- [NOIP2014] 提高组 洛谷P2038 无线网络发射器选址
题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...
- NOIP2002-2017普及组题解
虽然普及组一般都是暴力省一,但是有一些题目还是挺难的qwq个人觉得能进TG的题目会在前面打上'*' NOIP2002(clear) #include<bits/stdc++.h> usin ...
- NOIP2012 普及组 T3 摆花——S.B.S.
题目描述 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能超过ai盆,摆花时 ...
随机推荐
- ORA-28000: the account is locked-的解决办法
ORA-28000: the account is locked第一步:使用PL/SQL,登录名为system,数据库名称不变,选择类型的时候把Normal修改为Sysdba;第二步:选择myjob, ...
- [转]注释驱动的 Spring cache 缓存介绍
原文:http://www.ibm.com/developerworks/cn/opensource/os-cn-spring-cache/ 概述 Spring 3.1 引入了激动人心的基于注释(an ...
- 如何优化 FineUI 控件库的性能,减少 80% 的数据上传量!
在开始正文之前,请帮忙为当前排名前 10 唯一的 .Net 开源软件 FineUI 投一票: 投票地址: https://code.csdn.net/2013OSSurvey/gitop/codevo ...
- JSP 和 ASP.NET 谁能主宰未来【转】
随着计算机行业的发展,以后到底谁才是 web 网站开发的主宰者呢? 1. 说说JSP.(本人工作中用的最多的就是JSP) JSP. JavaServer Pages 是Java技术的一部分,可以说是J ...
- 为什么我们的web前端变的越来越复杂
前端发展了也有些年头了,曾记得很多年前,聊起前端,都觉得是很简单,那个时候都没有前端工程师这个职位.可现在,前端已经逆袭了,已经不是原来的样子了,各种技术层出不穷,显的越来越高深莫测了.前端真的变得那 ...
- ASP.NET MVC 数据库依赖缓存的实现
当数据库中的信息发生变化的时候,应用程序能够获取变化的通知是缓存依赖得以实现的基础.应用程序可以通过轮询获取数据变化的信息,使用轮询的话也不可能重新查一次后再和以前的数据做比较,如果这样的话如果我一个 ...
- GBDT(MART) 迭代决策树简介
以下对GBDT的介绍深入浅出,非常易懂 转自:http://blog.csdn.net/w28971023/article/details/8240756 GBDT(Gradient Boosting ...
- Bete冲刺第七阶段
Bete冲刺第七阶段 今日工作: web: 新增通知处理接口 ios: 重写登录逻辑,添加创建行程填写.注册 POP界面 目前所遇问题: web: web目前进展顺利,暂时还没有遇到编码的问题. iO ...
- 1110MySQL select实现原理
转自http://www.jianshu.com/p/NsWbRv 工作中需要借鉴MySQL对于select的具体实现,在网上搜了很久,几乎都是介绍原理的,对于实现细节都没有介绍,无奈之下只得自己对着 ...
- CSS Hack技术介绍及常用的Hack技巧
一.什么是CSS Hack? 不同的浏览器对CSS的解析结果是不同的,因此会导致相同的CSS输出的页面效果不同,这就需要CSS Hack来解决浏览器局部的兼容性问题.而这个针对不同的浏览器写不同的CS ...