HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯(lián)系
管理
poj1013Counterfeit Dollar
題意:十二枚硬幣中有一個與其它重量不一樣,用天平只稱三次,請推斷出哪一枚銀幣與其它不一樣,是輕了還是重了?
這是一道
to satisty
題目,就是去滿足給定的條件。
解這類題目的思路有兩種:
方法一、
假設(shè)不知道那一枚硬幣有問題,根據(jù)條件推測出有問題的硬幣。
方法二、
依次假設(shè)硬幣有問題,看那種假設(shè)滿足題意。
顯然,這類題目用第二種方法更好做,因為可以假設(shè)的情況是很少的。只需要把所有出現(xiàn)的硬幣都“懷疑”一遍就可以得到正確結(jié)果了。
代碼
1
import
java.io.
*
;
2
import
java.util.
*
;
3
class
Main
4
{
5
6
public
static
void
main(String[] args)
7
{
8
Scanner sc
=
new
Scanner(System.in);
9
int
n
=
sc.nextInt();
10
sc.nextLine();
11
for
(
int
i
=
0
; i
<
n; i
++
)
12
{
13
String strs[]
=
new
String[
3
];
14
strs[
0
]
=
sc.nextLine();
15
strs[
1
]
=
sc.nextLine();
16
strs[
2
]
=
sc.nextLine();
17
18
getRS(strs);
19
}
20
}
21
private
static
void
getRS(String[] strs)
{
22
TreeSet
<
Character
>
trset
=
new
TreeSet
<
Character
>
();
23
int
[] weights
=
new
int
[
300
];
24
for
(
int
i
=
0
; i
<
3
; i
++
)
25
{
26
char
[] chArry
=
strs[i].toCharArray();
27
for
(
int
j
=
0
; j
<
chArry.length; j
++
)
28
{
29
if
(Character.isUpperCase(chArry[j]))
30
{
31
trset.add(chArry[j]);
32
}
33
}
34
}
35
for
(
char
ch : trset)
//
may light
36
{
37
//
System.out.println("ch=" + ch);
38
Arrays.fill(weights,
0
);
39
weights[ch]
=
-
1
;
40
boolean
success
=
true
;
41
for
(
int
i
=
0
; i
<
3
; i
++
)
42
{
43
String[] strArry
=
strs[i].split(
"
"
);
44
int
wl
=
0
;
45
int
wr
=
0
;
46
char
[] chArry2
=
strArry[
0
].toCharArray();
47
for
(
char
ch2 : chArry2)
48
{
49
wl
+=
weights[ch2];
50
}
51
char
[] chArry3
=
strArry[
1
].toCharArray();
52
for
(
char
ch3 : chArry3)
53
{
54
wr
+=
weights[ch3];
55
}
56
if
(
!
getRSString(wl, wr).equals(strArry[
2
]))
57
success
=
false
;
58
}
59
if
(success)
60
{
61
System.out.println(ch
+
"
is the counterfeit coin and it is light.
"
);
62
return
;
63
}
64
}
65
//
66
for
(
char
ch : trset)
//
may heavy
67
{
68
69
Arrays.fill(weights,
0
);
70
weights[ch]
=
1
;
71
boolean
success
=
true
;
72
for
(
int
i
=
0
; i
<
3
; i
++
)
73
{
74
String[] strArry
=
strs[i].split(
"
"
);
75
int
wl
=
0
;
76
int
wr
=
0
;
77
char
[] chArry2
=
strArry[
0
].toCharArray();
78
for
(
char
ch2 : chArry2)
79
{
80
wl
+=
weights[ch2];
81
}
82
char
[] chArry3
=
strArry[
1
].toCharArray();
83
for
(
char
ch3 : chArry3)
84
{
85
wr
+=
weights[ch3];
86
}
87
if
(
!
getRSString(wl, wr).equals(strArry[
2
]))
88
success
=
false
;
89
}
90
if
(success)
91
{
92
System.out.println(ch
+
"
is the counterfeit coin and it is heavy.
"
);
93
return
;
94
}
95
}
96
}
97
private
static
String getRSString(
int
wl,
int
wr)
98
{
99
if
(wl
==
wr)
100
return
"
even
"
;
101
if
(wl
>
wr)
102
return
"
up
"
;
103
return
"
down
"
;
104
}
105
106
}
107
posted on 2013-03-22 22:31
小鼠標(biāo)
閱讀(162)
評論(0)
編輯
收藏
引用
所屬分類:
Java基礎(chǔ)練習(xí)
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
編輯距離
閏年判斷
正則表達(dá)式簡單筆記
Excel格式地址轉(zhuǎn)換
一道模擬題——機(jī)器人行走距離計算
排列練習(xí)2
素數(shù)篩法
排列組合練習(xí)
排列組合
poj1068Parencodings
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標(biāo) Powered by:
博客園
模板提供:
滬江博客
<
2013年3月
>
日
一
二
三
四
五
六
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
5
6
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(111)
C語言(3)
DP(9)
Java筆記(1)
Java基礎(chǔ)練習(xí)(25)
安卓(1)
本科畢設(shè)(1)
博弈(1)
大數(shù)(7)
回溯(2)
排序(10)
暑期培訓(xùn)周賽(3)
數(shù)據(jù)結(jié)構(gòu)(7)
數(shù)論(1)
水題(8)
圖論(24)
網(wǎng)選訓(xùn)練(8)
隨筆檔案
(127)
2014年3月 (1)
2013年7月 (10)
2013年5月 (1)
2013年4月 (11)
2013年3月 (8)
2012年10月 (1)
2012年9月 (12)
2012年8月 (38)
2012年7月 (14)
2012年6月 (2)
2012年5月 (8)
2012年4月 (6)
2012年3月 (6)
2012年2月 (4)
2011年8月 (5)
friends
陳鋼
大鵬
黨姐
焦林楓
汪濤
小白學(xué)長
媛姐
媛姐csdn
最新評論
1.?re: 線段樹
是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準(zhǔn)真的不是自己的原因呢。
加油,祝你好運(yùn)啦!
--小鼠標(biāo)
2.?re: 線段樹
對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網(wǎng)絡(luò)流
過來看看你。
--achiberx
4.?re: (轉(zhuǎn))ubuntu11.10無法啟動無線網(wǎng)絡(luò)的解決方法
膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區(qū)域賽難道是ACM區(qū)域賽。。?
--Hang
5.?re: 快速排序、線性時間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區(qū)基準(zhǔn)在數(shù)組中重復(fù)的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調(diào)隊列(5492)
2.?Linux select()函數(shù)使用(3979)
3.?快速排序、線性時間選擇(3690)
4.?poj3468--絕對經(jīng)典的線段樹題(3638)
5.?優(yōu)先隊列--堆實現(xiàn)(3304)
国产国产成人精品久久
|
日韩电影久久久被窝网
|
久久国产精品-久久精品
|
精品熟女少妇aⅴ免费久久
|
久久久久久国产a免费观看黄色大片
|
久久精品aⅴ无码中文字字幕不卡
|
97久久精品无码一区二区天美
|
久久成人国产精品一区二区
|
2021国内久久精品
|
国产成人精品久久一区二区三区av
|
久久精品一本到99热免费
|
99久久精品国产免看国产一区
|
亚洲欧洲久久久精品
|
大伊人青草狠狠久久
|
99久久精品国产一区二区
|
久久久精品国产亚洲成人满18免费网站
|
色欲综合久久中文字幕网
|
久久播电影网
|
99久久精品这里只有精品
|
国产三级久久久精品麻豆三级
|
久久久亚洲欧洲日产国码是AV
|
亚洲午夜无码AV毛片久久
|
99久久99久久精品国产片果冻
|
久久精品国产亚洲av麻豆小说
|
精品久久久无码人妻中文字幕
|
久久久久99精品成人片试看
|
人妻精品久久久久中文字幕
|
久久精品亚洲精品国产欧美
|
日本久久久精品中文字幕
|
久久国产精品-久久精品
|
国产午夜精品久久久久免费视
|
亚洲国产欧美国产综合久久
|
77777亚洲午夜久久多喷
|
亚洲午夜久久久久妓女影院
|
无码超乳爆乳中文字幕久久
|
久久久久久久久久久久久久
|
久久天天躁狠狠躁夜夜2020一
|
伊人色综合久久天天人守人婷
|
亚洲欧洲精品成人久久奇米网
|
麻豆久久久9性大片
|
日韩精品久久久久久免费
|