P2085 最小函式值 堆

2022-05-01 16:18:12 字數 1346 閱讀 1974

有n個函式,分別為f1,f2,...,fn。定義fi(x)=ai*x^2+bi*x+ci (x∈n*)。給定這些ai、bi和ci,請求出所有函式的所有函式值中最小的m個(如有重複的要輸出多個)。

輸入格式:

輸入資料:第一行輸入兩個正整數n和m。以下n行每行三個正整數,其中第i行的三個數分別位ai、bi和ci。ai<=10,bi<=100,ci<=10 000。

輸出格式:

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

輸入樣例#1: 複製

3 10

4 5 3

3 4 5

1 7 1

輸出樣例#1: 複製

9 12 12 19 25 29 31 44 45 54
資料規模:n,m<=10000

和上一題序列合併類似  用了類貪心思想 很重要!

#includeusing

namespace

std;

//input by bxd

#define rep(i,a,b) for(int i=(a);i<=(b);i++)

#define repp(i,a,b) for(int i=(a);i>=(b);--i)

#define ri(n) scanf("%d",&(n))

#define rii(n,m) scanf("%d%d",&n,&m)

#define riii(n,m,k) scanf("%d%d%d",&n,&m,&k)

#define rs(s) scanf("%s",s);

#define ll long long

#define pb push_back

#define rep(i,n) for(int i=0;i

#define clr(a,v) memset(a,v,sizeof a)

/////////////////////////////////

/#define inf 0x3f3f3f3f

const

int n=100000+5

;int

a[n];

intb[n];

intheap[n];

intfrom

[n];

intnow[n];

struct

node

}s[n];

intmain()

int cnt=1

; node head;

intlast;

while(cnt<=m)

return0;

}

view code

P2085 最小函式值 堆

題目描述 有n個函式,分別為f1,f2,fn。定義fi x aix 2 bix ci x n 給定這些ai bi和ci,請求出所有函式的所有函式值中最小的m個 如有重複的要輸出多個 輸入格式 輸入資料 第一行輸入兩個正整數n和m。以下n行每行三個正整數,其中第i行的三個數分別位ai bi和ci。ai...

P2085 最小函式值

有n個函式,分別為f1,f2,fn。定義fi x ai x 2 bi x ci x n 給定這些ai bi和ci,請求出所有函式的所有函式值中最小的m個 如有重複的要輸出多個 輸入格式 輸入資料 第一行輸入兩個正整數n和m。以下n行每行三個正整數,其中第i行的三個數分別位ai bi和ci。ai 10...

P2085 最小函式值

題目給你 n 個二次函式,給你 a b c 不過仔細的話可以發現 這三個係數都是正整數!所以意味著二次函式的對稱軸在x軸負半軸,在我們考慮的 1,infty 中的整數區間都是單調遞增的。所以同乙個函式中,x 1 時的函式值是最小的。如何求目標值?下面給出演算法。對於每個函式,是不是有乙個單調答案序列...