PAT乙级 1030. 完美数列(25)
1030. 完美数列(25)
给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列。
现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列。
输入格式:
输入第一行给出两个正整数N和p,其中N(<= 105)是输入的正整数的个数,p(<= 109)是给定的参数。第二行给出N个正整数,每个数不超过109。
输出格式:
在一行中输出最多可以选择多少个数可以用它们组成一个完美数列。
输入样例:
- 10 8
- 2 3 20 4 5 1 6 7 8 9
输出样例:
- 8
第一个版本
- #include "stdio.h"
- void sort(double a[],int n);
- void swap(double *a,double *b);
- int main(int argc, char const *argv[])
- {
- double a[],p;
- int i,n;
- scanf("%d %lf",&n,&p);
- getchar();
- for(i=;i<n;i++)
- scanf("%lf",&a[i]);
- sort(a,n);
- for(i=n-;i>;i--)
- {
- if(a[i]<=(a[]*p))
- {
- break;
- }
- }
- printf("%d\n",i+ );
- return ;
- }
- void sort(double a[],int n)
- {int i,j;
- for(i=;i<n;i++)
- {for(j=i+;j<n;j++)
- {
- if(a[i]>a[j])
- swap(a+i,a+j);
- }
- }
- }
- void swap(double *a,double *b)
- {
- double temp;
- temp=*a;
- *a=*b;
- *b=temp;
- }
第二个版本
- #include "stdio.h"
- #include "stdlib.h"
- int cmp(void const *a,void const*b);
- int main(int argc, char const *argv[])
- {
- double *a,p;
- int i,j,n,count=;
- while(~scanf("%d %lf",&n,&p))
- {
- a=(double*)malloc(n*sizeof(double));
- for(i=;i<n;i++)
- scanf("%lf",&a[i]);
- qsort(a,n,sizeof(double),cmp);
- for(i=;i<n;i++)//遍历将a[i]作为最小值
- for(j=i+count;j<n;j++)//
- {
- if(a[j]>(a[i]*p))
- break;
- if(j-i+>count)
- count=j-i+;
- }
- printf("%d\n",count );
- free(a);
- }
- return ;
- }
- int cmp(void const *a,void const*b)
- {
- return *((double*)a)-*((double*)b);
- }
思路:首先p与最小数相乘可能会超出int范围,所以这里用double,其次我们应该先将数组排序以方便计算,然后我们用双重for循环查找,查找的思路是从第一个元素作为最小数,开始往后找最大数,直到不符合条件,记录下此时的长度,然后将第二个元素作为最小数,再继续找,最后比较长度的最大值并输出,但是这样会超时,所以我们要对她进行优化,减少不必要的循环,优化的思路如下:
首先我们同样保持第一个for循环遍历最小值,在第二个for循环中我们将j置为前一个元素作为最小数时候的长度,这样就减少了小于上一次的不必要的for循环,j依然小于 N,用一个if判断是否符合条件,用另一个if判断此次是否大于上次的长度,比如说我们把样例中的数据已经排好序:1 2 3 4 5 6 7 8 9 20 ,此时我们将array[0]作为最小数,依次向后遍历,最大数j-最小数i+1即为数列的长度,最终找到8为最大的数,此时数列长度count为8,在将a[1]作为最小数的时候,我们直接将j置为1+8为9,直接比较a[1]和a[9]作为最小最大值得时候是否满足,不满足则a[1]最为最小数的时候并不能使数列变得更长,则继续再看a[2],这样等到有大于8的时候再更新,就可以
参考http://blog.csdn.net/wanmeiwushang/article/details/51456488
PAT乙级 1030. 完美数列(25)的更多相关文章
- 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,设这 ...
- PAT(B) 1030 完美数列 - C语言 - 滑动窗口 & 双指针
题目链接:1030 完美数列 (25 point(s)) 给定一个正整数数列,和正整数 \(p\),设这个数列中的最大值是 \(M\),最小值是 \(m\),如果 \(M≤mp\),则称这个数列是完美 ...
- PAT 1030. 完美数列(25)
给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列. 现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列. ...
- PAT (Basic Level) Practice (中文)1030 完美数列 (25 分) (有点意思)
给定一个正整数数列,和正整数 p,设这个数列中的最大值是 M,最小值是 m,如果 M≤mp,则称这个数列是完美数列. 现在给定参数 p 和一些正整数,请你从中选择尽可能多的数构成一个完美数列. 输入格 ...
- 1030 完美数列 (25 分)C、Java、python
题目描述 给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列. 现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完 ...
- P 1030 完美数列
转跳点:
随机推荐
- zepto源码--compact、flatten、camelize、dasherize、uniq--学习笔记
1.compact 删除数组中的空元素(不是空字符串).undefined.null 在定义变量时,定义过filter = emptyArray.filter,即调用javascript原生的数组处理 ...
- Wordpress制作sidebar.php
调用 在主页以下方法可以调用模板中sidebar.php的内容 <?php get_sidebar(); ?> 判断是否自定义sidebar侧边栏: <?php if ( !func ...
- Microsoft Dynamics AX 2009 White Paper: Close Non-Financial Transfers
http://www.microsoft.com/en-us/download/confirmation.aspx?id=12174
- sql 显示0001
- SQL Server 2008 R2,显示SQL语句执行窗口。 编辑前200行,可以执行SQL语句
- imx6 RGB LCD
imx6dl需要支持lcd接口的屏,imx6dl的datasheet并没有明确的说明lcd相关的配置,只在Display Content Integrity Checker (DCIC)一章中介绍.本 ...
- Notepad++ install vi plugin
下载Notepad++,想安装vi插件. 使用Notepad++自带的插件管理器下载visimulator失败. 所以直接下载插件visimulator.dll,再导入. 下载地址: https:// ...
- JQ实现accordion(可折叠)效果
先看效果--这个就是手风琴的效果: 原理:首先默认section1下面的dd可见,其他的全部隐藏:当点击某个obj时候, 快速隐藏全部的dd,然后只有obj.NEXT().show ...
- Linux权限值问题
0660:从左向右:第一位:(我不清楚,也没有用过)第二位:当前用户的经权限:6=110(二进制),每一位分别对就 可读,可写,可执行,,6说明当前用户可读可写不可执行第三位:group组用户,6的意 ...
- 第五篇 Integration Services:增量加载-Deleting Rows
本篇文章是Integration Services系列的第五篇,详细内容请参考原文. 在上一篇你学习了如何将更新从源传送到目标.你同样学习了使用基于集合的更新优化这项功能.回顾增量加载记住,在SSIS ...