当前位置: 首页>編程日記>正文

51nod 范德蒙矩阵

51nod 范德蒙矩阵

 

思路:  根据矩阵乘法的定义,G中的第i行第j列的元素 ai,j ,对答案的贡献为 ai,j∗ T中第j行的所有元素之和。

    因此我们可以将T中根据每行的和进行排序。第i行的和可以通过公式 (ai^n−1)/(ai−1)直接得出。
    注意考虑 ai=1,ai=0 以及 ai>MOD 的特殊情况即可。还有就是对于除法取模需要用到逆元(费马小定理)

    一开始没注意除法取模 狂WA 12遍也是心累。。。。。

 1 #include<iostream>
 2 #include<algorithm>
 3 #include<cstring>
 4 #include<cmath>
 5 
 6 using namespace std;
 7 typedef long long LL;
 8 const LL mod = 1e9 + 7;
 9 const int maxn = 1e5 + 10;
10 LL b[maxn], ans, a[maxn];
11 LL n, m;
12 LL Pow(LL a, LL b)//快速幂
13 {
14     LL ans = 1;
15     while (b) {
16         if (b & 1) {
17             ans *= a;ans %= mod;
18         }
19         a *= a;a %= mod;
20         b >>= 1;
21     }
22     return ans;
23 }
24 int main()
25 {
26     ios::sync_with_stdio(false);
27     while (cin >> n >> m) {
28         for (int i = 1; i <= m; i++) {
29             cin >> a[i];
30         }
31         sort(a + 1, a + m + 1);
32         for (int i = 1; i <= m; i++) {
33             a[i] = (a[i] % mod + mod) % mod;
34             if (a[i] == 0)b[i] = 1;
35             else if (a[i] == 1)b[i] = n;
36             else {                            //费马小定理对除法取模
37                 b[i] = (Pow(a[i], n) - 1 + mod) % mod;
38                 b[i] = b[i] * Pow(a[i] - 1, mod - 2) % mod;
39             }
40         }
41         //以下是求解
42         ans = 0;
43         LL num = (n*(n + 1) / 2) % mod;
44         for (int i = 1; i <= m; i++) {
45             ans = (ans + (num*b[i]) % mod) % mod;
46             num = (num + n * n) % mod;
47         }
48         cout << ans << endl;
49     }
50     return 0;
51 }

 

转载于:https://www.cnblogs.com/wangrunhu/p/9451812.html


https://www.fengoutiyan.com/post/14598.html

相关文章:

  • 用matlab生成范德蒙矩阵
  • 范德蒙德行列式计算
  • 范德蒙矩阵
  • 范德蒙行列式的转置
  • 矩阵
  • 范德蒙德矩阵的性质
  • matlab范德蒙德矩阵
  • 范德蒙行列式怎么计算
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機