posts - 12,  comments - 40,  trackbacks - 0
http://acm.pku.edu.cn/JudgeOnline/problem?id=3349
Snowflake Snow Snowflakes
原来用hash过的,后来发现mill竟然排序就过了,更惊奇的是用了一堆STL的东东。

mill一直是“自食其力”型选手,记得以前连STL里面的sort都懒得用,说自己写快排快些,习惯了。这次再看他代码,吓一跳,完全变了风格,里面动不动就是STL的东西,copy(),rotate(),reverse(),一堆,还有从没见过的lexicographical_compare(),算是长见识了,于是照着写了个,把代码留下,以后还用得着。
 1//3349
 2#include <algorithm>
 3using namespace std;
 4
 5const int N = 100010;
 6
 7int a[N][6];
 8int sign[N];
 9
10bool cmp(const int &x, const int &y) {
11    return lexicographical_compare(a[x],a[x]+6,a[y],a[y]+6);
12}

13int main() {
14    freopen("in.txt""r", stdin);
15    int n, i, j;
16    int b[6];
17    scanf("%d"&n);
18    for(i=0; i<n; i++{
19        for(j=0; j<6; j++{
20            scanf("%d", b+j);
21        }

22        copy(b, b+6, a[i]);
23        for(j=0; j<5; j++{
24            rotate(b, b+1, b+6);
25            if(lexicographical_compare(b, b+6, a[i], a[i]+6))
26                copy(b, b+6, a[i]);
27        }

28        reverse(b, b+6);
29        for(j=0; j<6; j++{
30            rotate(b, b+1, b+6);
31            if(lexicographical_compare(b, b+6, a[i], a[i]+6))
32                copy(b, b+6, a[i]);
33        }

34        sign[i] = i;
35    }

36    sort(sign, sign+n, cmp);
37    for(i=1; i<n; i++{
38        if(memcmp(a[sign[i-1]], a[sign[i]], sizeof(a[0])) == 0{
39            printf("Twin snowflakes found.\n");
40            return 0;
41        }

42    }

43    printf("No two snowflakes are alike.\n");
44    return 0;
45}

46
posted on 2007-08-18 13:03 LSM 阅读(604) 评论(0)  编辑 收藏 引用 所属分类: STL

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2007年8月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678

常用链接

留言簿(4)

随笔分类

随笔档案

牛牛 ACM/ICPC

最新随笔

搜索

  •  

最新随笔

最新评论

阅读排行榜

评论排行榜