POJ 尺取法
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 尺取法的更多相关文章
- POJ 3061 (二分+前缀和or尺取法)
题目链接: http://poj.org/problem?id=3061 题目大意:找到最短的序列长度,使得序列元素和大于S. 解题思路: 两种思路. 一种是二分+前缀和.复杂度O(nlogn).有点 ...
- POJ 3320 尺取法,Hash,map标记
1.POJ 3320 2.链接:http://poj.org/problem?id=3320 3.总结:尺取法,Hash,map标记 看书复习,p页书,一页有一个知识点,连续看求最少多少页看完所有知识 ...
- 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 ...
- POJ 3320 Jessica‘s Reading Problem(哈希、尺取法)
http://poj.org/problem?id=3320 题意:给出一串数字,要求包含所有数字的最短长度. 思路: 哈希一直不是很会用,这道题也是参考了别人的代码,想了很久. #include&l ...
- 尺取法 poj 2566
尺取法:顾名思义就是像尺子一样一段一段去取,保存每次的选取区间的左右端点.然后一直推进 解决问题的思路: 先移动右端点 ,右端点推进的时候一般是加 然后推进左端点,左端点一般是减 poj 2566 题 ...
- POJ 3320 尺取法(基础题)
Jessica's Reading Problem Description Jessica's a very lovely girl wooed by lots of boys. Recently s ...
- 尺取法 POJ 3320 Jessica's Reading Problem
题目传送门 /* 尺取法:先求出不同知识点的总个数tot,然后以获得知识点的个数作为界限, 更新最小值 */ #include <cstdio> #include <cmath> ...
- 尺取法 POJ 3601 Subsequence
题目传送门 /* 题意:求连续子序列的和不小于s的长度的最小值 尺取法:对数组保存一组下标(起点,终点),使用两端点得到答案 1. 记录前i项的总和,求[i, p)长度的最小值,用二分找到sum[p] ...
- POJ 3061 Subsequence 二分或者尺取法
http://poj.org/problem?id=3061 题目大意: 给定长度为n的整列整数a[0],a[1],--a[n-1],以及整数S,求出总和不小于S的连续子序列的长度的最小值. 思路: ...
随机推荐
- AIFramework框架Jittor特性(上)
AIFramework框架Jittor特性(上)
- python+selenium基础篇,cookie绕过验证码小案例
1.绕过验证码有许许多多的方法,笔者在此介绍其中的一个小方法,原理其实就是获取已登陆了之后的凭证(会话保存在本地的cookie中)再打开另一个页面的使用 2.F12(浏览器开发者调试工具)可以查看的需 ...
- Python_Selenium 之PO模式的思想、优化思路
一.PO模式思想 PO模式是一种自动化测试设计模式,将页面定位和业务操作分开,也就是把对象的定位和测试脚本分开,从而提供可维护性. PO设计模式基础(页面作为类.元素对象作为属性.元素操作作为方法) ...
- 源码简析Spring-Integration执行过程
一,前言 Spring-Integration基于Spring,在应用程序中启用了轻量级消息传递,并支持通过声明式适配器与外部系统集成.这一段官网的介绍,概况了整个Integration的用途.个人感 ...
- dataguard日志损坏处理
===== 问题 ===== 日志损坏无法应用日志(开启MRP应用系统会因无法应用日志而关闭) Completed: ALTER DATABASE RECOVER MANAGED STANDBY DA ...
- flume实时采集mysql数据到kafka中并输出
环境说明 centos7(运行于vbox虚拟机) flume1.9.0(flume-ng-sql-source插件版本1.5.3) jdk1.8 kafka(版本忘了后续更新) zookeeper(版 ...
- mybatis在动态 SQL 中使用了参数作为变量,必须要用 @Param 注解
如果在动态 SQL 中使用了参数作为变量,那么就要用 @Param 注解,即使你只有一个参数.如果我们在动态 SQL 中用到了 参数作为判断条件,那么也是一定要加 @Param 注解的,例如如下方法: ...
- 「题解」300iq Contest 2 B Bitwise Xor
本文将同步发布于: 洛谷博客: csdn: 博客园: 简书. 题目 题目链接:gym102331B. 题意概述 给你一个长度为 \(n\) 的序列 \(a_i\),求一个最长的子序列满足所有子序列中的 ...
- MySQL8性能优化
MySQL8.0 引擎: 来看看MySQL8提供的引擎: 常用引擎: InnoDB:支持事务,行级锁,外键,崩溃修复,多版本并发控制:读写效率相对较差,内存使用相对较高,占用数据空间相对较大. MyI ...
- 备份schema并排除大表到ASM磁盘上
1.查出占用空间比较大的表 select owner,segment_name,segment_type,bytes/1024/1024 mb from dab_segment where owner ...