HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
poj1013Counterfeit Dollar
題意:十二枚硬幣中有一個與其它重量不一樣,用天平只稱三次,請推斷出哪一枚銀幣與其它不一樣,是輕了還是重了?
這是一道
to satisty
題目,就是去滿足給定的條件。
解這類題目的思路有兩種:
方法一、
假設不知道那一枚硬幣有問題,根據條件推測出有問題的硬幣。
方法二、
依次假設硬幣有問題,看那種假設滿足題意。
顯然,這類題目用第二種方法更好做,因為可以假設的情況是很少的。只需要把所有出現的硬幣都“懷疑”一遍就可以得到正確結果了。
代碼
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
小鼠標
閱讀(169)
評論(0)
編輯
收藏
引用
所屬分類:
Java基礎練習
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
編輯距離
閏年判斷
正則表達式簡單筆記
Excel格式地址轉換
一道模擬題——機器人行走距離計算
排列練習2
素數篩法
排列組合練習
排列組合
poj1068Parencodings
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標 Powered by:
博客園
模板提供:
滬江博客
<
2025年7月
>
日
一
二
三
四
五
六
29
30
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
7
8
9
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(111)
C語言(3)
DP(9)
Java筆記(1)
Java基礎練習(25)
安卓(1)
本科畢設(1)
博弈(1)
大數(7)
回溯(2)
排序(10)
暑期培訓周賽(3)
數據結構(7)
數論(1)
水題(8)
圖論(24)
網選訓練(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
陳鋼
大鵬
黨姐
焦林楓
汪濤
小白學長
媛姐
媛姐csdn
最新評論
1.?re: 線段樹
是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
加油,祝你好運啦!
--小鼠標
2.?re: 線段樹
對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
--傷心的筆
3.?re: poj1273--網絡流
過來看看你。
--achiberx
4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
--Hang
5.?re: 快速排序、線性時間選擇
博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
--lsxqw2004
閱讀排行榜
1.?單調隊列(5498)
2.?Linux select()函數使用(3991)
3.?快速排序、線性時間選擇(3721)
4.?poj3468--絕對經典的線段樹題(3643)
5.?優先隊列--堆實現(3310)
国产亚洲欧美成人久久片
|
精品一久久香蕉国产线看播放
|
欧美丰满熟妇BBB久久久
|
国内精品久久久久影院优
|
亚洲国产精品成人久久蜜臀
|
亚洲精品无码久久久久
|
久久综合九色综合精品
|
亚洲国产天堂久久综合
|
精品久久久久久无码专区
|
国产成人精品久久亚洲
|
国产精品久久久香蕉
|
精品一区二区久久久久久久网站
|
日韩AV毛片精品久久久
|
久久久噜噜噜www成人网
|
久久国产精品偷99
|
久久久久久久久无码精品亚洲日韩
|
久久亚洲高清观看
|
国产A三级久久精品
|
丰满少妇人妻久久久久久4
|
国产A三级久久精品
|
久久国产视频99电影
|
国产精品免费看久久久
|
国产精品一区二区久久精品涩爱
|
一本久久久久久久
|
无码人妻久久一区二区三区免费丨
|
国内精品久久久久影院一蜜桃
|
色婷婷久久综合中文久久一本
|
999久久久无码国产精品
|
国产精品久久久久a影院
|
国产精品免费久久久久影院
|
久久综合88熟人妻
|
亚洲国产一成久久精品国产成人综合
|
国产产无码乱码精品久久鸭
|
久久夜色精品国产噜噜亚洲a
|
中文字幕亚洲综合久久
|
久久99精品久久久久久久久久
|
久久久一本精品99久久精品88
|
国产福利电影一区二区三区久久久久成人精品综合
|
久久国产视频99电影
|
国产精品久久久久久福利69堂
|
99久久99久久精品国产片果冻
|