PAT1030 完美數列

2021-07-30 13:34:13 字數 1233 閱讀 2955

給定乙個正整數數列,和正整數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本題是最後一道大題,最後的ac**只有30多行,用到了快速排序,對大陣列定義的一些細節考察,節省執行時間的一些技巧都有涉及,是一道比較綜合的題目。

#include#include#includeint cmp(const void* a,const void* b)

int main()

count = j; //因為前乙個temp肯定大於等於a[j]之前的數,所有不必每次從第乙個數開始判斷.

}printf("%d",max);

}

double

double是計算機使用的一種資料型別。比起單精度浮點數(float),double(雙精度浮點數)使用 64 位(8位元組) 來儲存乙個浮點數。 它可以表示十進位制的15或16位有效數字,負值取值範圍為 -1.7976e+308 到 -4.94065645841246544e-324,正值取值範圍為 4.94065645841246544e-324 到 1.797693e+308。

double在計算機中的儲存方法:無論是單精度還是雙精度在儲存中都分為三個部分:

符號位(sign) : 0代表正,1代表為負

指數字(exponent):用於儲存科學計數法中的指數資料,並且採用移位儲存

尾數部分(mantissa):尾數部分

正是它不同於long long的儲存方法,使得它雖然只有64位但是可以比同樣是64位的long long 型別取值範圍大很多。

long long 

64位的範圍應該是[-2^63 ,2^63],既-9223372036854775808~9223372036854775807。

它的儲存方法就是按位儲存。有符號位就有一位符號位,沒有符號位就64位全部來儲存這個數。

pat 1030 完美數列

給定乙個正整數數列,和正整數p,設這個數列中的最大值是m,最小值是m,如果m m p,則稱這個數列是完美數列。現在給定引數p和一些正整數,請你從中選擇盡可能多的數構成乙個完美數列。輸入格式 輸入第一行給出兩個正整數n和p,其中n 10 5 是輸入的正整數的個數,p 10 9 是給定的引數。第二行給出...

PAT 1030完美數列

0.背景 給定乙個正整數數列,和正整數p,設這個數列中的最大值是m,最小值是m,如果m m p,則稱這個數列是完美數列。現在給定引數p和一些正整數,請你從中選擇盡可能多的數構成乙個完美數列。輸入格式 輸入第一行給出兩個正整數n和p,其中n 105 是輸入的正整數的個數,p 109 是給定的引數。第二...

PAT 1030 完美數列

給定乙個正整數數列,和正整數p,設這個數列中的最大值是m,最小值是m,如果m m p m m p m m p,則稱這個數列是完美數列。現在給定引數p和一些正整數,請你從中選擇盡可能多的數構成乙個完美數列。輸入格式 輸入第一行給出兩個正整數n和p,其中n 105 10 10 5 是輸入的正整數的個數,...