為生存而奔跑
::
首頁
::
聯系
::
聚合
::
管理
271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks
留言簿
(5)
給我留言
查看公開留言
查看私人留言
我參與的團隊
隨筆分類
Algorithm(73)
C#(19)
Design Pattern(16)
Effective STL / C++ (12)
Information Retrival / Data Mining(13)
Java(25)
Linux kernel(2)
MFC(16)
Python(5)
TopCoder(1)
Ubuntu&Linux(56)
技術(12)
無聊(2)
雜(22)
隨筆檔案
2011年5月 (1)
2011年4月 (6)
2011年3月 (21)
2011年2月 (9)
2011年1月 (12)
2010年12月 (2)
2010年11月 (3)
2010年10月 (6)
2010年8月 (13)
2010年7月 (11)
2010年6月 (7)
2010年5月 (21)
2010年4月 (15)
2010年3月 (16)
2010年1月 (5)
2009年12月 (18)
2009年11月 (18)
2009年10月 (19)
2009年9月 (8)
2009年8月 (42)
2009年7月 (15)
2009年4月 (3)
相冊
Girl
搜索
積分與排名
積分 - 328415
排名 - 74
最新評論
1.?re: Invoke與BeginInvoke
講得很好,清晰明了
--YJJ
2.?re: Invoke與BeginInvoke
講的這么好, 為啥沒有人頂呢
--zhouandke
3.?re: 數組分割問題
轉載請注明
--呵呵
4.?re: HDU 3415 單調隊列
話說,sum數組為什么只開10W就能過,如果n=100000,k=100000,明顯要開20W啊
--KissLL
5.?re: GDB 單步調試
文章太強大了。
--kangear
閱讀排行榜
1.?GDB 單步調試(33342)
2.?Emacs教程(20830)
3.?解決“windows無法連接到選定網絡 網絡可能不在區域中”(11474)
4.?Invoke與BeginInvoke(9594)
5.? Eclipse下搭建SWT開發環境(8009)
評論排行榜
1.?C/C++沒有數組(12)
2.?HDU 3415 單調隊列(8)
3.?Ubuntu Linux常見中文輸入法匯總(7)
4.?word畫圖里自選圖形里面的連接符不能用(5)
5.?<編程之美>數組分割問題(3)
【矩陣問題】PKU 3070
pku 3070
題目要求計算Fibonacci數列的第n項最后4位。因為n可以很大(0 ≤
n
≤ 1,000,000,000)。因此直接計算在時限內是不可能的(有多個case)。題目還給出了計算的方法:表示成矩陣連乘的形式為
求第n項的后4位,相當于求第n項模10000的余數。而矩陣的乘法滿足邊乘邊模。矩陣乘法還滿足結合律,所以可以先計算出上面的一個矩陣的2的冪次方的值,記錄下來。然后對于每一個n,將它表示成2進制。如當n=5時,只需計算一次矩陣乘法:1次方乘以4次方。當n=1000000000時最多只需計算29次矩陣乘法2^29 = 536870912)
#include
<
iostream
>
#include
<
algorithm
>
#include
<
string
>
#include
<
vector
>
#include
<
cmath
>
#include
<
map
>
using
namespace
std;
int
m[
31
][
4
],fact[
31
];
int
n;
void
init()
{
fact[
1
]
=
1
;
m[
1
][
0
]
=
1
; m[
1
][
1
]
=
1
; m[
1
][
2
]
=
1
; m[
1
][
3
]
=
0
;
for
(
int
i
=
2
;i
<=
30
;i
++
)
{
m[i][
0
]
=
(m[i
-
1
][
0
]
*
m[i
-
1
][
0
]
+
m[i
-
1
][
1
]
*
m[i
-
1
][
2
])
%
10000
;
m[i][
1
]
=
(m[i
-
1
][
0
]
*
m[i
-
1
][
1
]
+
m[i
-
1
][
1
]
*
m[i
-
1
][
3
])
%
10000
;
m[i][
2
]
=
(m[i
-
1
][
2
]
*
m[i
-
1
][
0
]
+
m[i
-
1
][
3
]
*
m[i
-
1
][
2
])
%
10000
;
m[i][
3
]
=
(m[i
-
1
][
2
]
*
m[i
-
1
][
1
]
+
m[i
-
1
][
3
]
*
m[i
-
1
][
3
])
%
10000
;
fact[i]
=
fact[i
-
1
]
*
2
;
}
}
void
solve()
{
bool
vis[
31
]
=
{
0
}
;
//
對n表示成2進制
for
(
int
i
=
30
;i
>
0
;i
--
)
if
(n
>=
fact[i])
{
n
-=
fact[i];
vis[i]
=
1
;
}
int
res[
4
]
=
{
1
,
0
,
0
,
1
}
;
//
單位矩陣
int
tmp[
4
];
for
(
int
i
=
1
;i
<=
30
;i
++
)
{
if
(vis[i])
{
tmp[
0
]
=
(res[
0
]
*
m[i][
0
]
+
res[
1
]
*
m[i][
2
])
%
10000
;
tmp[
1
]
=
(res[
0
]
*
m[i][
1
]
+
res[
1
]
*
m[i][
3
])
%
10000
;
tmp[
2
]
=
(res[
2
]
*
m[i][
0
]
+
res[
3
]
*
m[i][
2
])
%
10000
;
tmp[
3
]
=
(res[
2
]
*
m[i][
1
]
+
res[
3
]
*
m[i][
3
])
%
10000
;
for
(
int
j
=
0
;j
<
4
;j
++
)
res[j]
=
tmp[j];
}
}
printf(
"
%d\n
"
,res[
1
]);
}
int
main()
{
init();
while
(scanf(
"
%d
"
,
&
n)
!=
EOF
&&
n
!=-
1
)
{
solve();
}
}
posted on 2009-08-17 10:57
baby-fly
閱讀(259)
評論(0)
編輯
收藏
引用
所屬分類:
Algorithm
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
二分搜索 找上下界
算法導論上的歸并排序
PKU 2184 dp
PKU 2392 多重背包
PKU 2823 Sliding Window 單調隊列
HDU 3415 單調隊列
t
CRecordSet
KMP字符串模式匹配詳解
HDU 3450 樹狀數組 離散化
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright @ baby-fly
Powered by:
.Text
and
ASP.NET
Theme by:
.NET Monster
国产精品久久影院
|
午夜不卡888久久
|
久久综合色老色
|
久久人人爽人人爽人人片av高请
|
色偷偷久久一区二区三区
|
久久综合综合久久狠狠狠97色88
|
久久精品视屏
|
久久久无码精品亚洲日韩按摩
|
久久国产精品久久精品国产
|
久久久久久av无码免费看大片
|
久久精品国产精品亚洲精品
|
久久久无码精品亚洲日韩软件
|
久久93精品国产91久久综合
|
无码人妻久久一区二区三区
|
国产亚洲精久久久久久无码AV
|
亚洲香蕉网久久综合影视
|
精品久久人人爽天天玩人人妻
|
香蕉久久一区二区不卡无毒影院
|
欧美日韩精品久久久免费观看
|
亚洲国产精品久久久久婷婷软件
|
日本五月天婷久久网站
|
国产精品成人99久久久久
|
精品久久久久久国产牛牛app
|
久久久久亚洲av综合波多野结衣
|
久久国产精品二国产精品
|
色婷婷狠狠久久综合五月
|
久久精品www
|
A狠狠久久蜜臀婷色中文网
|
久久婷婷五月综合国产尤物app
|
欧美久久精品一级c片片
|
99久久99久久
|
99久久国产综合精品麻豆
|
久久亚洲欧美国产精品
|
伊人久久综合精品无码AV专区
|
亚洲人成无码网站久久99热国产
|
久久国产精品波多野结衣AV
|
久久久久国色AV免费看图片
|
久久精品成人一区二区三区
|
欧美久久天天综合香蕉伊
|
久久人人超碰精品CAOPOREN
|
久久男人AV资源网站
|