HDU 4944 FSF’s game(計數遊戲)
題目連結:
http://acm.hdu.edu.cn/showproblem.php?pid=4944
題意:
給定一個長度n, 用長度為 a,b 的邊組成一個矩形 (1<=a<=b<=n) 我們可以將其組成n(n+1)/2個不同的矩形,
對於每一個矩形 我們可以得到一個val val=sigma(a*b/gcd(a/k,b/k)) 其中k為a,b的公因子,求這個val;
分析:
我們定義一個函式calu(i,j) calu(i,j)的意思是sigma{(i*j/gcd(i/k,j/k))},
則ans=sigma {calu(i,j)}(1<=i<=j<=n);
我們設dp[n]表示最大的邊長為n的邊所得到的val,
那麼dp[n]=dp[n-1]+sigma{ calu(i,n) }(1<=i<=n)
然後我們需要解決的問題就是求sigma{ calu(i,n) }(1<=i<=n);
我們先討論calu(i,n)=n*(i/c1+i/c2+...),其中cj為n和i的最大公約數d的所有因子。
那麼我們可以列舉所有n的因子j,對於因子j,存在這個因子且小於等於n的數字中有j,2*j,3*j,...,n。
我們可以得到s[j]=(1+2+3+...n/j)*n=(n/j+1)*(n/j)/2*n。
那麼val[n]=sigma{fun(i,n)}(1<=i<=n)=sigma{s[j]} (j為n的因子)。
程式碼如下:
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long LL;
const LL mod = (LL)1<<32;
const int maxn = 500010;
LL cnt[maxn],dp[maxn];
void init()
{
memset(cnt,0,sizeof(cnt));
for(LL i=1;i<maxn;i++){//列舉因子
for(LL j=i;j<maxn;j+=i)//統計因子的個數的和
cnt[j]+=(j/i+1)*(j/i)/2;
}
}
void solve()
{
dp[1]=1;
for(int i=2;i<maxn;i++){
dp[i]=(dp[i-1]+i*cnt[i])%mod;
}
}
int main()
{
int t,n,cas=1;
init();
solve();
scanf("%d",&t);
while(t--){
scanf("%d",&n);
printf("Case #%d: %I64d\n",cas++,dp[n]);
}
return 0;
}
相關文章
- Switch Game HDU - 2053GAM
- HDU 5299 Circles Game(樹的刪邊遊戲)GAM遊戲
- HDU1729 Stone Game (SG函式)GAM函式
- FSF:2015FSF年度報告 程式設計支出佔85%程式設計
- 《遊戲設計模式》(Game Programming Patterns)遊戲設計設計模式GAM
- HDU 3074 Multiply game(線段樹 單點更新)GAM
- HDU 4326Game(比較難理解的概率dp)GAM
- HDU 1846-Brave Game(巴什博弈-SG函式)GAM函式
- Relax! It's just a game(排列組合,簡單)GAM
- HDU 5973-Game of Taking Stones(威佐夫博弈-JAVA BigDecimal)GAMJavaDecimal
- HDU44979 GCD and LCM (素因子分解+計數)GC
- Game with points(數學,難度中)GAM
- HDU5348 MZL's endless loop (搜尋)OOP
- 網易遊戲周家科:從體驗推進遊戲美術設計丨N.GAME遊戲GAM
- [CareerCup] 17.5 Game of Master Mind 猜字遊戲GAMAST遊戲
- [CareerCup] 8.8 Othello Game 黑白棋遊戲GAM遊戲
- HDU 4550卡片遊戲(貪心)遊戲
- hdu 3177Crixalis's Equipment(貪心)UI
- HDU 5131 Song Jiang's rank list(排序)排序
- jquery 60s倒數計時jQuery
- Flutter Flame 教程2 -- Game Loop遊戲迴圈FlutterGAMOOP遊戲
- [CareerCup] 7.1 Basketball Shooting Game 投籃遊戲GAM遊戲
- (一)django-game:model 設計DjangoGAM
- 遊戲設計靈感發源地《Game UI Database》資料庫網站上線遊戲設計GAMUIDatabase資料庫網站
- HDU-1466 計算直線的交點數 DP
- HDU 2662 Coin && HDU 1792 A New Change Problem (互質數最大不能生成數)
- 「殺時間」遊戲:爆火之後,Game Over?遊戲GAM
- Game Informer :免費遊戲變好玩了嗎?GAMORM遊戲
- leetcode 679. 24 Game(遊戲24點)LeetCodeGAM遊戲
- 模擬經營類遊戲(Simulation Game)綜述遊戲GAM
- facebook instant game 釋出指南-小遊戲 SDKGAM遊戲
- Elements Of A Game Engine - 3D遊戲引擎原理 (轉)GAM3D遊戲引擎
- Linux之父Torvalds對FSF表示“厭煩”(轉)Linux
- hdu 2097 Java Sky數Java
- hdu 1792 A New Change Problem(數論)
- HDU 1466 計算直線的交點數(簡單dp)
- Facebook Instant Game 小遊戲上傳的遊戲包有大小限制GAM遊戲
- HDU 4349 Xiao Ming's Hope (Lucas定理的應用)