PAT 1030 完美數列 25

2022-09-18 13:36:17 字數 1101 閱讀 8937

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

思路很簡單。對於乙個已經排序好的數列,找到不大於,這個數列最小元素乘以p的元素個數。

但要注意兩點,

1.不用每次都從選定數列的首元素可以找,因為當前數列首元素一定大於上乙個數列的首元素,可以從上個數列找到的元素個數字置開始找。

2.最大元素個數要在每次j++時判斷。不能找得到大於最小元素乘以p的元素位置時判斷,因為可能所有元素都小於最小元素乘以p元素

1 #include2 #include

3 #include4

int cmp(const

void* a,const

void*b)

7int

main()

14int max = 0;15

int count = 0

; 16 qsort(a,n,sizeof(a[0

]),cmp);

17double

temp;

18int

i,j;

19for(i=0;i)

25if(j-i>=max)

26 max = j-i+1;27

28}29 count =j;

3031

}32 printf("%d"

,max);

33 }

PAT 1030 完美數列 25

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

PAT1030完美數列 25

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

PAT1030完美數列(25)分

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