1. 程式人生 > >最小函數值(minval)

最小函數值(minval)

else atom bsp 個數 min element -s max 時間

最小函數值(minval)

鏈接:http://ybt.ssoier.cn:8088/problem_show.php?pid=1370
時間限制: 1000 ms 內存限制: 65536 KB

【題目描述】

有n個函數,分別為F1,F2,...,FnF1,F2,...,Fn。定義Fi(x)=Aix2+Bix+Ci(xN?)Fi(x)=Aix2+Bix+Ci(x∈N?)。給定這些AiBiAi、Bi和CiCi,請求出所有函數的所有函數值中最小的m個(如有重復的要輸出多個)。

【輸入】

第一行輸入兩個正整數n和m。

以下n行每行三個正整數,其中第i行的三個數分別位AiAi、BiBi和CiCi。輸入數據保證

Ai<=10Bi<=100Ci<=10000Ai<=10,Bi<=100,Ci<=10000。

【輸出】

將這n個函數所有可以生成的函數值排序後的前m個元素。這m個數應該輸出到一行,用空格隔開。

【輸入樣例】

3 10
4 5 3
3 4 5
1 7 1

【輸出樣例】

9 12 12 19 25 29 31 44 45 54

【提示】

【數據規模】

n,m<=10000

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include
<vector> #include <algorithm> using namespace std; const int maxn = 10005; int A[maxn],B[maxn],C[maxn],x[maxn],y[maxn]; int n,m; int js(int A,int B,int C,int X) { return A*X*X+B*X+C; } int main() { cin>>n>>m; for(int i=1;i<=n;i++) { scanf("%d%d%d",&A[i],&B[i],&C[i]); x[i]
=max((B[i]+1)/((-2)*A[i]),1); y[i]=js(A[i],B[i],C[i],x[i]); } int j=0,flag=0; y[0]=210000005; while(j<m) { int k=0; for(int i=1;i<=n;i++) if(y[i]<y[k])k=i; if(flag)printf(" %d",y[k]); else{flag=1;printf("%d",y[k]);} y[k]=js(A[k],B[k],C[k],++x[k]); j++; } return 0; }

最小函數值(minval)