珠心算测验

模拟。

将所有“两个不同数之和”装进桶里,扫描原数组记录满足条件的数的个数。

 /*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] 普及组的更多相关文章

  1. 【NOIP2014 普及组】螺旋矩阵

    [NOIP2014 普及组]螺旋矩阵 一.题目 [NOIP2014 普及组]螺旋矩阵 时间限制: 1 Sec  内存限制: 128 MB 提交: 18  解决: 0 [提交][状态][讨论版] 题目描 ...

  2. noip2014普及组——珠心算测验

    题目描述 珠心算是一种通过在脑中模拟算盘变化来完成快速运算的一种计算技术.珠心算训练,既能够开发智力,又能够为日常生活带来很多便利,因而在很多学校得到普及.    某学校的珠心算老师采用一种快速考察珠 ...

  3. 螺旋矩阵 noip2014普及组

    本题可以直接模拟填数字,也可以直接计算结果. 代码一:(这个代码,缺陷在于数组太大,浪费内存啊.另外,循环次数也不少.总之,时间空间的消耗都不小.) /*======================= ...

  4. noip2014普及组 比例简化

    题目描述 在社交媒体上,经常会看到针对某一个观点同意与否的民意调查以及结果.例如,对某一观点表示支持的有1498 人,反对的有 902人,那么赞同与反对的比例可以简单的记为1498:902. 不过,如 ...

  5. [NOIP2014普及组]子矩阵

    题目:洛谷P2258.Vijos P1914.codevs 3904. 题目大意:给你一个矩阵,要你找一个r行c列的子矩阵,求最小分值(子矩阵和分值的定义见原题). 解题思路:n和m比较小,考虑暴力. ...

  6. [NOIP2014普及组T1]珠心算测验 - NTT

    求数组有多少个数,恰好等于集合中另外两个(不同的)数之和? 注意到数集比较小,而且涉及到下标的加法,可以很自然地想到卷积 注意减去自己加自己的贡献 真是一道NTT练手好题 #include <i ...

  7. [NOIP2014] 提高组 洛谷P2038 无线网络发射器选址

    题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...

  8. NOIP2002-2017普及组题解

    虽然普及组一般都是暴力省一,但是有一些题目还是挺难的qwq个人觉得能进TG的题目会在前面打上'*' NOIP2002(clear) #include<bits/stdc++.h> usin ...

  9. NOIP2012 普及组 T3 摆花——S.B.S.

    题目描述 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能超过ai盆,摆花时 ...

随机推荐

  1. mybatis 3.2.7 与 spring mvc 3.x、logback整合

    github上有一个Mybatis-Spring的项目,专门用于辅助完成mybatis与spring的整合,大大简化了整合难度,使用步骤: 准备工作: maven依赖项: <properties ...

  2. vmware安装cent os 6.5 + oracle 11g xe + jboss eap 6.2 + weblogic 12c+ webshpere mq 7.5

    前言: mac系统发展速度确实很快,短短数年,mac os上已经能网银支付(中行.招行.工商.支付宝等均已全面支持mac os了),windows上的经典常用软件:qq.飞信.旺旺.有道词典.有道云笔 ...

  3. 实验三 敏捷开发与XP实践

    实验内容 1. XP基础 2. XP核心实践 3. 相关工具 实验要求 1.没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim编辑器> 课程 2.完成实验 ...

  4. 谈谈patch strategy

    所谓的patch strategy,就是软件发布后出现bug时打补丁的方式 - 主要是关于源代码branch如何组织的方式 针对项目的开发阶段.开发状态.维护方式不同,可以有不同的patching s ...

  5. iptables实现负载均衡

    例子: iptables -t nat -A PREROUTING -d 10.192.0.65/32 -p tcp -m tcp --dport 8080 -m statistic --mode n ...

  6. NVelocity学习笔记一——linq2sql+NVelocity完整demo

    (一)前言      刚刚进入新公司,看公司的项目,发现开发流程几乎和以前的完全不同,再看看页面布局竟然没有发现html.神马情况????一番探究发现使用了NVelocity模板引擎开发的.于是乎花了 ...

  7. DOM Element节点类型详解

    上文中我们讲解了 DOM 中最重要的节点类型之一的 Document 节点类型,本文我们继续深入,谈谈另一个重要的节点类型 Element . 1.概况 Element 类型用于表现 HTML 或 X ...

  8. 用 Linux自带的logrotate 来管理日志

    大家可能都有管理日志的需要,比如定时压缩日志,或者当日志超过一定大小时就自动分裂成两个文件等.最近就接到这样一个小任务.我们的程序用的是C语言,用log4cpp的library来实现日志记录.但是问题 ...

  9. auto refresh iframe

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <t ...

  10. 关于insert /*+ append*/ 各种insert插入速度比较

    来源于:http://www.cnblogs.com/rootq/archive/2009/02/11/1388043.html SQL> select count(*) from t;COUN ...