HooLee
If you believe, you can!
C++博客
首頁
新隨筆
新文章
聯系
管理
poj1007DNA Sorting
簡單的排序題,用TreeSet實現。
TreeSet的排序方式有兩種:
1.讓元素自身具有可比較性,這種方法稱為自然順序或者默認順序
2.讓容器自身具有可比較性
這里是介紹第一中方法,這種方法的做法是利用元素自身的比較性,即元素實現
Comparable接口,覆蓋campareTo()方法
。
再拓展一下。我們知道set中的元素不僅是有序的,而且是不能重復的,如何判斷元素是否重復呢?TreeSet和HashSet判斷方法并不一樣。在自然順序時,TreeSet判斷元素是否相同的依據是
compareTo()是否返回0
,remove()和contains()也調用此方法。
代碼
1
import
java.io.
*
;
2
import
java.util.
*
;
3
import
java.math.
*
;
4
class
Main
5
{
6
7
public
static
void
main(String[] args)
8
{
9
Scanner sc
=
new
Scanner(System.in);
10
11
int
n, m;
12
n
=
sc.nextInt();
13
m
=
sc.nextInt();
14
sc.nextLine();
15
TreeSet
<
MyClass
>
strset
=
new
TreeSet
<
MyClass
>
();
16
for
(
int
i
=
0
; i
<
m; i
++
)
17
{
18
StringBuffer buf1
=
new
StringBuffer(sc.nextLine());
19
20
int
value
=
0
;
21
for
(
int
j
=
0
; j
<
n
-
1
; j
++
)
22
{
23
for
(
int
k
=
j
+
1
; k
<
n; k
++
)
24
{
25
if
(buf1.charAt(j)
-
buf1.charAt(k)
>
0
)
26
value
++
;
27
}
28
}
29
30
strset.add(
new
MyClass(buf1, value, i));
31
}
32
33
/**/
/*
for(MyClass myct : strset)
34
{
35
//System.out.println("::" + myct.getBuf() + "::v=" + myct.getValue()
36
// + "::seq=" + myct.getSeq());
37
System.out.println(myct.getBuf());
38
}
*/
39
Iterator
<
MyClass
>
it
=
strset.iterator();
40
while
(it.hasNext())
41
{
42
MyClass myc
=
it.next();
43
System.out.println(myc.getBuf());
44
}
45
46
}
47
48
}
49
class
MyClass
implements
Comparable
<
MyClass
>
50
{
51
private
StringBuffer buf;
52
private
int
value;
53
private
int
seq;
54
public
MyClass(StringBuffer buf,
int
value,
int
seq)
55
{
56
this
.buf
=
buf;
57
this
.value
=
value;
58
this
.seq
=
seq;
59
}
60
public
StringBuffer getBuf()
61
{
62
return
buf;
63
}
64
public
int
getValue()
65
{
66
return
this
.value;
67
}
68
public
int
getSeq()
69
{
70
return
this
.seq;
71
72
}
73
public
int
compareTo(MyClass myc2)
74
{
75
int
t
=
this
.value
-
myc2.value;
76
if
(t
==
0
)
77
return
this
.seq
-
myc2.seq;
78
return
t;
79
80
}
81
}
82
posted on 2013-03-17 21:13
小鼠標
閱讀(249)
評論(0)
編輯
收藏
引用
所屬分類:
Java基礎練習
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
編輯距離
閏年判斷
正則表達式簡單筆記
Excel格式地址轉換
一道模擬題——機器人行走距離計算
排列練習2
素數篩法
排列組合練習
排列組合
poj1068Parencodings
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 小鼠標 Powered by:
博客園
模板提供:
滬江博客
<
2012年3月
>
日
一
二
三
四
五
六
26
27
28
29
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
常用鏈接
我的隨筆
我的評論
我參與的隨筆
隨筆分類
(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.?單調隊列(5493)
2.?Linux select()函數使用(3980)
3.?快速排序、線性時間選擇(3690)
4.?poj3468--絕對經典的線段樹題(3639)
5.?優先隊列--堆實現(3304)
国产成人久久精品区一区二区
|
人妻少妇精品久久
|
久久ww精品w免费人成
|
亚洲中文字幕无码久久综合网
|
日产精品久久久一区二区
|
免费国产99久久久香蕉
|
久久天天日天天操综合伊人av
|
亚洲欧洲久久av
|
欧美亚洲国产精品久久蜜芽
|
精品综合久久久久久88小说
|
亚洲中文久久精品无码ww16
|
欧美久久综合性欧美
|
精品国产青草久久久久福利
|
国产91久久精品一区二区
|
亚洲人成网站999久久久综合
|
精品久久久久久久久午夜福利
|
久久久精品国产亚洲成人满18免费网站
|
国产亚洲精久久久久久无码
|
国产精品美女久久久久AV福利
|
久久久久久精品免费看SSS
|
久久伊人精品青青草原高清
|
蜜臀av性久久久久蜜臀aⅴ麻豆
|
日日狠狠久久偷偷色综合免费
|
午夜精品久久久久久久
|
久久精品无码av
|
国产精品美女久久久
|
久久99热这里只有精品66
|
一本大道久久a久久精品综合
|
精品国产乱码久久久久久郑州公司
|
美女久久久久久
|
久久精品综合一区二区三区
|
国产精品久久久久久久午夜片
|
国产亚洲色婷婷久久99精品
|
亚洲AV无码久久精品蜜桃
|
国产精品久久久久久久app
|
深夜久久AAAAA级毛片免费看
|
久久久99精品成人片中文字幕
|
久久精品成人免费国产片小草
|
777午夜精品久久av蜜臀
|
亚洲婷婷国产精品电影人久久
|
久久精品亚洲男人的天堂
|