1030 完美數列

2021-07-29 13:07:32 字數 867 閱讀 9518

給定乙個正整數數列,和正整數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

這道題較難,剛開始我以為數列中最大的那個數就一定是最長數列中的m,提交**後也發現過了5個檢測點,其實這種演算法是錯的。

後來我從n到1依次迴圈判斷m<=m*p,但是執行超時

最後又正序判斷,從最大數/p這個數開始,可是已經執行超時

在參考網上的資源了解到,可以在一次迴圈後,直接判斷從乙個數到與他距離為上乙個最大個數的值是否滿足m<=m*p,是的話一次往後推導

關於最後乙個檢測點,與變數資料型別有關,這裡得用long

16位系統:long是4位元組,int是2位元組

32位系統:long是4位元組,int是4位元組

64位系統:long是8位元組,int是4位元組

#include#include#include#include#includeusing namespace std;

int main()

sort(myin,myin+n);

for(i=0;i

1030 完美數列

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

1030 完美數列

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

1030 完美數列

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