poj3061 Subsequence

题目链接: http://poj.org/problem?id=3061

挑战P146。题意:给定长度为n的数列整数a0,a1,...,a(n-1)以及整数S,求出总和不小于S的连续子序列的长度的最小值,如果解不存在,则输出零。$10<n<10^5,0<a_i<=10^4,S<10^8$;

思路:尺取法,设起始下标s,截止下标e,和为sum,初始时s=e=0;若sum<S,将sum增加a(e),并将e加1,若sum>=S,更新t-s,并将sum减去a(s),sj增加1,再和S比较,重复该步骤,直接附上书上代码

#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
int main(){
int x,a[100005];
cin>>x;
while(x--){
int s=0,t=0,sum=0,S,n,ans;
cin>>n>>S;
ans=n+1;
for(int i=0;i<n;i++)
cin>>a[i];
for(;;){
while(t<n&&sum<S){
sum+=a[t++];
}
if(sum<S)
break;
ans=min(ans,t-s);
sum-=a[s++];
}
if(ans>n)
cout<<0<<endl;
else cout<<ans<<endl; }
}

poj2566 Bound Found

题目链接:http://poj.org/problem?id=2566

题意:已知一个长度为n的整数序列和非负数t,求该序列中一个连续的子序列,使其和的绝对值最接近t,输出该序列的左右下标;

这题是《挑战》上尺取法部分的习题,暴力肯定会T,开始觉得尺取法不可做,看了下题解发现自己还是太菜了,稍微变下形就不会了,,,,

尺取法一般数列都是有序的,给的数列不是有序的,只要求出他们的前缀和再排个序就变成有序的了,用了一个结构体z[i]保存前缀和信息,z[i].x表示前i个数的和,由于排序后i会变化,故z[i].y记录初始的i,排序后即可使用尺取法更新最接近t值得左右下标,讲的应该比较清楚了哦->_->

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
int n,k,a[100005];
struct Z{
int x;
int y;
}z[100005];
bool cmp(Z a,Z b){
return a.x<b.x;
}
int main(){
while(scanf("%d%d",&n,&k)&&(n!=0||k!=0)){
z[0].x=z[0].y=0;
for(int i=0;i<n;i++){
scanf("%d",&a[i]);
z[i+1].x=z[i].x+a[i];
z[i+1].y=i+1;
}
sort(z,z+n+1,cmp);
for(int i=0;i<k;i++){
int p;int s=0,t=1,temp,minn=0x3f3f3f3f,l,r,ans;
scanf("%d",&p);
while(s<=n&&t<=n){
temp=z[t].x-z[s].x;
if(abs(temp-p)<minn){
minn=abs(temp-p);
l=z[t].y;
r=z[s].y;
ans=temp;
}
if(temp>p)
s++;
else if(temp<p)
t++;
else break;
if(s==t)
t++;
} printf("%d %d %d\n",ans,min(l,r)+1,max(l,r));
} }
}

poj2100 Graveyard Design

题目链接:http://poj.org/problem?id=2100

题意:已知一个数n,问是否存在一个连续的自然数序列使他们的平方和为n,按序列长度从大到小输出序列的长度和整个序列

尺取法,和poj3061基本一样,由于输出要求,只要用个结构体记录下长度和起始下标即可。

#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
struct Z{
long long int x,y,z;
}z[1000005];
int main(){
long long int ans=0,S,s=1,t=1,sum=0;
cin>>S;
for(;;){
while(sum<S){
sum+=t*t;
t++;
}
if(sum==S){
z[ans].x=t-s;
z[ans].y=s;
z[ans].z=t-1;
ans++;
}
sum-=s*s;
s++;
if(s*s>S) break;
}
if(ans==0)
cout<<0<<endl;
else {
cout<<ans<<endl;
for(int i=0;i<ans;i++){
cout<<z[i].x<<" ";
int j;
for( j=z[i].y;j<z[i].z;j++)
cout<<j<<" ";
cout<<j<<endl;
}
}
}

poj2739 Sum of Consecutive Prime Numbers

题目链接: http://poj.org/problem?id=2739

题意:已知一个数n,(2<=n<=10000);若n能表示成若干个连续的素数的和,则称n为consecutive prime numbers,问n有多少种表示方法;

思路:先将n以内的数筛选法打个素数表,再用尺取法判断即可;

#include<cstdio>
#include<iostream>
using namespace std;
int prime[10005],ans[10005]={0},is_prime[10005];
int main(){
int p=0;
for(int i=0;i<=10000;i++)
is_prime[i]=1;
is_prime[1]=is_prime[1]=0;
for(int i=2;i<=10000;i++){
if(is_prime[i]){
prime[p++]=i;
for(int j=2*i;j<=10000;j+=i)
is_prime[j]=false;
}
}
int s=0,t=0,sum=0;
for(;;){
while(t<10000&&sum<=10000){
sum+=prime[t++];
ans[sum]++;
}
sum=0;s++;t=s;
if(prime[s]>10000)
break;
}
int n;
while((cin>>n)&&n!=0){
cout<<ans[n]<<endl;
}
}

  

  

POJ 尺取法的更多相关文章

  1. POJ 3061 (二分+前缀和or尺取法)

    题目链接: http://poj.org/problem?id=3061 题目大意:找到最短的序列长度,使得序列元素和大于S. 解题思路: 两种思路. 一种是二分+前缀和.复杂度O(nlogn).有点 ...

  2. POJ 3320 尺取法,Hash,map标记

    1.POJ 3320 2.链接:http://poj.org/problem?id=3320 3.总结:尺取法,Hash,map标记 看书复习,p页书,一页有一个知识点,连续看求最少多少页看完所有知识 ...

  3. POJ 3320 Jessica's Reading Problem 尺取法

    Description Jessica's a very lovely girl wooed by lots of boys. Recently she has a problem. The fina ...

  4. POJ 3320 Jessica‘s Reading Problem(哈希、尺取法)

    http://poj.org/problem?id=3320 题意:给出一串数字,要求包含所有数字的最短长度. 思路: 哈希一直不是很会用,这道题也是参考了别人的代码,想了很久. #include&l ...

  5. 尺取法 poj 2566

    尺取法:顾名思义就是像尺子一样一段一段去取,保存每次的选取区间的左右端点.然后一直推进 解决问题的思路: 先移动右端点 ,右端点推进的时候一般是加 然后推进左端点,左端点一般是减 poj 2566 题 ...

  6. POJ 3320 尺取法(基础题)

    Jessica's Reading Problem Description Jessica's a very lovely girl wooed by lots of boys. Recently s ...

  7. 尺取法 POJ 3320 Jessica's Reading Problem

    题目传送门 /* 尺取法:先求出不同知识点的总个数tot,然后以获得知识点的个数作为界限, 更新最小值 */ #include <cstdio> #include <cmath> ...

  8. 尺取法 POJ 3601 Subsequence

    题目传送门 /* 题意:求连续子序列的和不小于s的长度的最小值 尺取法:对数组保存一组下标(起点,终点),使用两端点得到答案 1. 记录前i项的总和,求[i, p)长度的最小值,用二分找到sum[p] ...

  9. POJ 3061 Subsequence 二分或者尺取法

    http://poj.org/problem?id=3061 题目大意: 给定长度为n的整列整数a[0],a[1],--a[n-1],以及整数S,求出总和不小于S的连续子序列的长度的最小值. 思路: ...

随机推荐

  1. 2.5D Visual Sound:CVPR2019论文解析

    2.5D Visual Sound:CVPR2019论文解析 论文链接: http://openaccess.thecvf.com/content_CVPR_2019/papers/Gao_2.5D_ ...

  2. 使用OneFlow搭建神经网络

    使用OneFlow搭建神经网络 在 识别 MNIST 手写体数字 的例子中,通过 flow.layers 和 flow.nn 中提供的接口搭建了一个简单的 LeNet 网络.下面,将通过LeNet来介 ...

  3. AI+IoT+电池应用

    AI+IoT+电池应用 AIoT电池 突破你的想象 将行业领先的电池电化学技术与前沿的能源物联网最佳实践相结合,利用智能物联技术开展电池全生命周期的管理优化和交叉领域的协同应用,解锁动力电池全生命周期 ...

  4. 用NVIDIA-TensorRT构造深度神经网络

    用NVIDIA-TensorRT构造深度神经网络 Deploying Deep Neural Networks with NVIDIA TensorRT NVIDIA TensorRT是一个用于生产环 ...

  5. Seata分布式事务框架Sample

    前言 阿里官方给出了seata-sample地址,官方自己也对Sample提供了很多类型,可以查看学习. 我这里选择演示SpringBoot+MyBatis. 该聚合工程共包括5个module: sb ...

  6. 面试官就是要问我SpringMVC的源码,差点顶不住!

    <对线面试官>系列目前已经连载22篇啦!有深度风趣的系列! [对线面试官]Java注解 [对线面试官]Java泛型 [对线面试官] Java NIO [对线面试官]Java反射 & ...

  7. MySQL面试题汇总

    事务是什么? 一系列操作,要么全部完成,要么一个都不做 事务的ACID特性 原子性:一系列操作要么都执行,要么都不执行 一致性:事务执行前后数据完整性不变,如转账前后总金额不变 隔离性:多个事务并发访 ...

  8. springmvc自定义的拦截器以及拦截器的配置

    一.自定义拦截器 Spring MVC也可以使用拦截器对请求进行拦截处理,用户可以自定义拦截器来实现特定的功能,自定义的拦截器必须实现HandlerInterceptor接口. 二.HandlerIn ...

  9. 【Android编程实战】源码级免杀_Dex动态加载技术_Metasploit安卓载荷傀儡机代码复现

    /文章作者:MG193.7 CNBLOG博客ID:ALDYS4 QQ:3496925334/ 在读者阅读本文章前,建议先阅读笔者之前写的一篇对安卓载荷的分析文章 [逆向&编程实战]Metasp ...

  10. 【NX二次开发】Block UI 通过浏览选择文件夹

    属性说明 属性   类型   描述   常规           BlockID    String    控件ID    Enable    Logical    是否可操作    Group    ...