給定乙個正整數數列,和正整數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 #include3 #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 是輸入的正整...