C++心路历程
C++博客
首页
新随笔
新文章
联系
聚合
管理
posts - 33, comments - 25, trackbacks - 0
ZOJ 1272 解题报告
将
大数类
稍做修改(主要是输出的修改,每三个数字加上逗号),26进制的数字转换,比较简单.
Code
1
#include
"
BigInteger.h
"
2
#include
<
iostream
>
3
using
namespace
std;
4
5
bool
IsDigit(
string
s)
6
{
7
if
(s.length()
==
0
)
8
return
false
;
9
return
isdigit((
int
)s.at(
0
));
10
}
11
12
char
ConvertToChar(
int
value)
13
{
14
return
(
char
)(value
+
'
a
'
-
1
);
15
}
16
17
int
_tmain(
int
argc, _TCHAR
*
argv[])
18
{
19
string
input;
20
bool
isDigit;
21
while
(cin
>>
input
&&
input
!=
"
*
"
)
22
{
23
isDigit
=
IsDigit(input);
24
25
if
(isDigit)
26
{
27
BigInteger integer(input);
28
BigInteger zero(
0
);
29
30
vector
<
char
>
result;
31
while
(integer
!=
zero)
32
{
33
BigInteger r
=
integer
%
26
;
34
result.push_back(ConvertToChar(r.GetIntValue()));
35
integer
=
integer
/
26
;
36
}
37
vector
<
char
>
::reverse_iterator end
=
result.rend();
38
int
length
=
0
;
39
for
(vector
<
char
>
::reverse_iterator ite
=
result.rbegin(); ite
!=
end;
++
ite)
40
{
41
cout
<<
(
*
ite);
42
++
length;
43
}
44
while
(
++
length
<
23
)
45
cout
<<
"
"
;
46
cout
<<
BigInteger(input)
<<
endl;
47
}
48
else
49
{
50
int
length
=
input.length();
51
BigInteger result(
0
);
52
BigInteger p(
26
);
53
for
(
int
i
=
length
-
1
; i
>=
0
;
--
i)
54
{
55
result
=
result
+
BigInteger((
int
)(input.at(i)
-
'
a
'
+
1
))
*
p.Pow(length
-
1
-
i);
56
}
57
cout
<<
input;
58
int
index
=
length;
59
while
(
++
index
<
23
)
60
cout
<<
"
"
;
61
cout
<<
result
<<
endl;
62
}
63
}
64
return
0
;
65
}
66
67
posted on 2009-03-26 21:59
肖羽思
阅读(439)
评论(0)
编辑
收藏
引用
所属分类:
ZOJ
只有注册用户
登录
后才能发表评论。
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
相关文章:
ZOJ 1813 解题报告
ZOJ 1406 解题报告
ZOJ 1350 解题报告
ZOJ 1249 解题思路
ZOJ 1151 解题报告
ZOJ 1113 解题报告
ZOJ 1059 解题报告
ZOJ 1057 解题报告
ZOJ 1210 解题报告
ZOJ 1160 解题报告
网站导航:
博客园
IT新闻
BlogJava
博问
Chat2DB
管理
<
2009年3月
>
日
一
二
三
四
五
六
22
23
24
25
26
27
28
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
常用链接
我的随笔
我的评论
我参与的随笔
留言簿
(3)
给我留言
查看公开留言
查看私人留言
随笔分类
POJ(4)
ZOJ(29)
随笔档案
2009年4月 (10)
2009年3月 (23)
文章分类
POJ(1)
ZOJ(1)
文章档案
2009年3月 (2)
搜索
最新评论
1. re: ZOJ 1059 解题报告
让人
--让人
2. re: POJ 1753 解题报告
LZ的位运算计算法果然比我的普通方法快很多啊!!!
感谢分享!!!
--hacker003
3. re: POJ 1753 解题报告
这算法好像有冗余吧
FlipPiece(6585,0)=6570之后就不用FlipPiece(6570,0)了吧
--yangyh
4. re: POJ 1517 解题报告
这样的话不是每一次都要重复计算阶乘的么?很浪费时间的。。。。
--WayneWu
5. re: POJ 2965 解题报告
@Tanky Woo
你说的不对,你根本没看楼主的算法,结果必定为1
--刘灏
阅读排行榜
1. POJ 1753 解题报告(5000)
2. POJ 2965 解题报告(3725)
3. ZOJ 1204 解题报告(2133)
4. ZOJ 1004 解题报告(1904)
5. ZOJ 1091 解题报告(1323)
评论排行榜
1. POJ 1753 解题报告(8)
2. POJ 2965 解题报告(8)
3. ZOJ 1004 解题报告(2)
4. ZOJ 1210 解题报告(2)
5. ZOJ 1059 解题报告(1)