PAT(B) 1030 完美数列 - C语言 - 滑动窗口 & 双指针
给定一个正整数数列,和正整数 \(p\),设这个数列中的最大值是 \(M\),最小值是 \(m\),如果 \(M≤mp\),则称这个数列是完美数列。
现在给定参数 \(p\) 和一些正整数,请你从中选择尽可能多的数构成一个完美数列。
输入格式:
输入第一行给出两个正整数 \(N\) 和 \(p\),其中 \(N\)(\(≤10^5\))是输入的正整数的个数,\(p\)(\(≤10^9\))是给定的参数。第二行给出 \(N\) 个正整数,每个数不超过 \(10^9\)。
输出格式:
在一行中输出最多可以选择多少个数可以用它们组成一个完美数列。
输入样例:
10 8
2 3 20 4 5 1 6 7 8 9
输出样例:
8
题解
如果用双层循环的话,肯定是会超时的。
需要先排序。再用滑动窗口(双指针)来解决此题。
不断移动右边界。然后用左边界向右移动不断试探。并记录最大值。
示例过程如下:
1、先升序排序
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
---|---|---|---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
2、两个指针 \(left\) 和 \(right\) 指向第一个数据,最大长度 \(maxLen = 0\)
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) \(right\) |
3、因为 \(1 * 8 > 1\),且 \(1 > maxLen\),所以 \(maxLen = 1\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
4、因为 \(1 * 8 > 2\),且 \(2 > maxLen\),所以 \(maxLen = 2\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
5、因为 \(1 * 8 > 3\),且 \(3 > maxLen\),所以 \(maxLen = 3\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
6、因为 \(1 * 8 > 4\),且 \(4 > maxLen\),所以 \(maxLen = 4\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
7、因为 \(1 * 8 > 5\),且 \(5 > maxLen\),所以 \(maxLen = 5\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
8、因为 \(1 * 8 > 6\),且 \(6 > maxLen\),所以 \(maxLen = 6\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
9、因为 \(1 * 8 > 7\),且 \(7 > maxLen\),所以 \(maxLen = 7\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
10、因为 \(1 * 8 = 8\),且 \(8 > maxLen\),所以 \(maxLen = 8\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
11、因为 \(1 * 8 < 9\),所以 \(left\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
12、因为 \(2 * 8 > 9\),\(right\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
13、因为 \(2 * 8 < 20\),\(left\) 右移
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 20 |
---|---|---|---|---|---|---|---|---|---|
\(left\) | \(right\) |
14、因为 \(3 * 8 > 20\),\(right\) 右移,\(right = N\),所以结束,因此最终结果是 \(8\)
C代码
/*********************************************************************
Score: 25
Problem: 1030
Compiler: C(gcc)
Run Time: 25ms
Version: 1.2
Author: wowpH
Date: 2019-11-22 21:38:27
From: https://www.cnblogs.com/wowpH/p/11914428.html
*********************************************************************/
#include <stdio.h>
#include <stdlib.h>
#define MAX_N 100000
long long arr[MAX_N];// 乘法会超过int型范围
int compare(const void* a, const void* b);
int main(void) {
int N, p;
scanf("%d %d", &N, &p);
for (int i = 0; i < N; ++i) {
scanf("%lld", &arr[i]);
}
qsort(arr, N, sizeof(long long), compare);// 头文件stdlib.h
int left = 0;
int right = 0;
int maxLen = 0;
while (right < N) {
while (left < N && arr[left] * p < arr[right]) {// mp>=M
++left;
}
if (right - left + 1 > maxLen) {
maxLen = right - left + 1;
}
++right;
}
printf("%d\n", maxLen);
return 0;
}
int compare(const void* a, const void* b) {
return *(int*)a - *(int*)b;// 升序
}
原文链接:https://www.cnblogs.com/wowpH/p/11914428.html
- End - wowpH - cnblogs -
PAT(B) 1030 完美数列 - C语言 - 滑动窗口 & 双指针的更多相关文章
- PAT乙级 1030. 完美数列(25)
1030. 完美数列(25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 给定一个正整数数列,和正整数p,设这 ...
- PAT 乙级1030 完美数列(25) C++版
1030. 完美数列(25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 给定一个正整数数列,和正整数p,设这 ...
- PAT Basic 1030 完美数列 (25 分)
给定一个正整数数列,和正整数 p,设这个数列中的最大值是 M,最小值是 m,如果 M≤mp,则称这个数列是完美数列. 现在给定参数 p 和一些正整数,请你从中选择尽可能多的数构成一个完美数列. 输入格 ...
- PAT (Basic Level) Practise (中文)-1030. 完美数列(25)
PAT (Basic Level) Practise (中文)-1030. 完美数列(25) http://www.patest.cn/contests/pat-b-practise/1030 给 ...
- PAT-乙级-1030. 完美数列(25)
1030. 完美数列(25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 给定一个正整数数列,和正整数p,设这 ...
- P 1030 完美数列
转跳点:
- PAT——1030. 完美数列
给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列. 现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列. ...
- PAT 1030. 完美数列(25)
给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列. 现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列. ...
- PAT (Basic Level) Practise:1030. 完美数列
[题目链接] 给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列. 现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一 ...
随机推荐
- [RN] React Native 键盘管理 在Android TextInput遮盖,上移等问题解决办法
React Native 键盘管理 在Android TextInput遮盖,上移等问题解决办法 解决办法: 打开android工程,在AndroidManifest.xml中配置如下: <ac ...
- wireshark安装和使用 -基础篇
使用前知道: wireshark版本:3.0.2 使用wireshark的目的是因为它支持linux/windows/mac,而且新版本是开源免费的.还有一个原因是使用Fiddler不支持mac.截止 ...
- 创建第一个react项目
前提:已安装部署好nodejs环境 查看nodejs是否安装以及版本 1,win+r输入cmd打开命令行页面 2,路径换到nodejs目录 3,输入node -v查看版本 创建项目 1,win+r输入 ...
- FFmpeg 被声明为已否决 deprecated(2018 精)
不用再取消SDL检查,不用再添加#pragma warning(disable :4996),下面才是正确的解决方法!! 以下是一些常见的deprecated问题,遇到下述没有列出的问题,可以打开相应 ...
- mysql-创建用户报错ERROR 1396 (HY000): Operation CREATE USER failed for 'root'@'localhost'
创建用户: create user ‘test’@’%’ identified by ‘test’; 显示ERROR 1396 (HY000): Operation CREATE USER faile ...
- 使用ssh-keygen生成私钥和公钥
1.使用ssh-keygen生成私钥和公钥 命令如下: ssh-keygen -t rsassh-keygen -t rsa -C "用户名自取"可以是邮箱 例子: fdipzon ...
- jetty demo实例启动
Jetty是一个提供HHTP服务器.HTTP客户端和javax.servlet容器的开源项目.Jetty和tomcat相比,是轻量级服务器,支持热拔插,可扩展性大tomcat集成了很多功能,个性化瘦身 ...
- ES6----拓展运算符 三个点【...】
[...]拓展运算符是什么? es6中引入扩展运算符(...),它用于把一个数组转化为用逗号分隔的参数序列,它常用在不定参数个数时的函数调用,数组合并等情形.因为typeScript是es6的超集,所 ...
- thinkjs框架发布上线PM2管理,静态资源访问配置
一.环境:thinkjs + pm2 二.网站配置: #端口转发 location / { proxy_pass http://127.0.0.1:8368; } #静态资源(很重要) set $no ...
- 查找算法(2)--Binary chop--二分查找
1. 二分查找 (1)说明 元素必须是有序的,如果是无序的则要先进行排序操作. (2)基本思想: 也称为是折半查找,属于有序查找算法.用给定值k先与中间结点的关键字比较,中间结点把线形表分成两个子表, ...