作者:
bravooooo (bravooooo)
2022-05-16 09:44:42開發平台(Platform): (Ex: Win10, Linux, ...)
ubuntu 12.x
編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出)
g++
額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
問題(Question):
大家好 最近遇到一個演算法的問題
題目是要求解 a1/(1+a1*b1*s) + a2/(1+a2*b2*s)... + an/(1+an*bn*s)
加總後的各個係數
以2項為例就是:
a1/(1+a1*b1*s) + a2/(1+a2*b2*s) =
分母通分 → [a1(1+a2*b2) + a2(1+a1*b1)] *s / (1+a1*b1*s)(1+a2*b2*s) =
[a1(1+a2*b2) + a2(1+a1*b1)] *s / [1 + (a1*b1+a2*b2)s + (a1*b1*a2*b2)s^2]
上式中黃色部份即為所求
題目的多項式用暴力展開可以得到分母部份可以用組合公式把每一項求出
但若 n的值太大組合數會超多 計算量也跟著爆炸
不知道像這種題目有沒有什麼更好的解法呢
述敘的有點亂請大家見諒 也謝謝大家幫忙 Q_Q
餵入的資料(Input):
預期的正確結果(Expected Output):
錯誤結果(Wrong Output):
程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔)
補充說明(Supplement):
你的 (a1, a2,...,an) 和 (b1,b2,...bn) 是有規則的嗎?
作者:
bravooooo (bravooooo)
2022-05-16 13:02:00沒有規則的哦 QQ
作者: hongsiangfu 2022-05-16 14:39:00
s domain model? 只能找通分後的係數規則了
Iteration的作法應該就是你說的暴力法? ((1,2)處理後跟3) Divide and Conquer有用上了嗎? 會變O(logN)
bn是不是沒有單獨用到...?可以先把an*bn算一下?
更:D&C應無助益,因為s的最高次方在不同層的時候不同
應該是沒特別辦法 沒有規則又每一個都要算出來大概就是把算過的先存起來 或考慮一些恆等式
作者: hellophoenix (Rainey) 2022-05-16 17:39:00
能不能看看n=3的長相,也許很規律
直接算會太多嗎?an, bn 如果都整數用陣列存s多項式分母部分直接乘或d&c來做大數乘法 假設結果為P ,分子只需要在利用大數除法算出 sum ai * P/(1+aibis) 這樣?
作者:
oToToT (å±å©)
2022-05-16 19:54:00推薦個Prob_Solve板然後分治應該做得到T(n)=2T(n/2)+O(多項式乘法)的複雜度吧如果多項式乘法naive套個fft的話應該可以O(n log^2 n)?(分母部分)