珠心算测验

模拟。

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

 /*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. Linux 网络编程详解三(p2p点对点聊天)

    //p2p点对点聊天多进程版--服务器(信号的使用) #include <stdio.h> #include <stdlib.h> #include <string.h& ...

  2. Spring JDBCTemplate使用JNDI数据源

    xml配置: <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverMana ...

  3. TinyFrame续篇:整合Spring IOC实现依赖注入

    上一篇主要讲解了如何搭建基于CodeFirst的ORM,并且在章节末我们获取了上下文对象的实例:BookContext.这节主要承接上一篇,来讲解如何整合Spring IOC容器实现控制反转,依赖注入 ...

  4. .net 动态代理的泛型方法支持问题

    最近一直在做.net平台下的高速服务框架.其中有一个问题一直困扰着我:通过动态代理RealProxy创建的服务代理,不支持泛型方法调用.比如: 接口声明: public interface IMete ...

  5. CentOs下jdk的安装

    jdk的安装是咱搞java的基本功了,在window上配置了没上百次也有几十次了,今天换个环境,需要在linux系统上安装,而服务器版本的CentOs是纯命令行的, 因此也给配置jdk增加了不少难度, ...

  6. 初学git:用git bash往github push代码

    对于我来说,最开始使用github主要是为了使用它的pages功能展示demo.其实这些都是用Github for Windows push上去的,图形化界面的客户端使用确实简单,但是逼格不够,好吧其 ...

  7. Java程序-进程中的"进程"

    进程 我们知道程序在磁盘上的时候是静态的,当他被加载到内存的时候,就变成了一个动态的,称为进程,如下图是程序被加载到内存后,在内存中的分布情况如下      此图来自http://blog.csdn. ...

  8. 备忘:maven 错误信息: Plugin execution not covered by lifecycle configuration

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  9. Android开发之SlidingMenu开源项目的使用和问题

    一.关于如何导入lib 第一步:New Module  点击+: 第二步:选择Import Eclipse ADT Project: 第三步:选择你想引入的lib文件,选择完成后,会开始编译你添加的项 ...

  10. iOS 'The sandbox is not sync with the Podfile.lock'问题解决

    问题描述: github下载的Demo,很多时候使用到CocoaPods,有的时候因为依赖关系或者版本问题不能编译运行.出现例如The sandbox is not sync with the Pod ...