2014NYIST校赛ACM-ICPC竞赛环境的配置(PC^2)总结

个人感觉这次比赛环境的搭建不是很成功。而且为了搭建其比赛的环境也是一波多则。但是后来还是逐一解决了问题。在比赛开始前算是解决了主要的大部分问题,但是还有一个最重要的问题在比赛时候一直没有解决。赛后自己通过不断的总结反思和查阅资料才发现了问题的所在。对于那些因为我的环境搭配错误而可能正确A题的同学深感抱歉~

先解决主要问题为什么会出现环境搭配的致命性错误因为,从这次比赛之前自己都没有独立搭建过比赛环境。而这次也是临时学习。而且就自己一个人独自配置,很多问题出现了不知道如何处理。最后跟人能力有限导致了本次比赛环境失败的根本原因。由于一开始用静态文件在ubuntu系统上安装jdk并不是很熟悉。所以,自己就在网上查阅了很多资料发现有一个傻瓜式的装法,就是直接在软件园直接安装OpenJDK这就是给比赛的失败埋下了伏笔。好来赛后查阅资料发现OpenJDK和JDK是有一定的区别的。(原文

Sun jdk与Openjdk版本发展历史如下图所示:

1、    Openjdk的前身是Sun公司的JDK虚拟机,最初Java标准是由Sun公司制定的,他们也开发出了严格遵循Java标准的Java虚拟机JDK,在当时JDK源代码不是开放的,只是由Sun公司内部的开发者进行维护。当时比较流行的版本是JDK6和JDK7,他们在代码结构和风格上有较大的不同。随着开源成为软件发展的一个必然趋势,在广大开发者和爱好者的呼吁下, 2007年5月9日, Sun公司在GPL V2协议下,开放了JDK7的大部分代码,成立了Openjdk项目,该项目由Openjdk社区来维护,Openjdk社区从理论上来说是独立于Sun公司的。这样就形成了Openjdk的第一个版本——Openjdk7;

2、    Sun公司在成立Openjdk项目之后,原来的JDK6版本还继续维护,这样Openjdk7和JDK6并行发展。Openjdk7由JDK7代码开源而来,继承了JDK7的代码结构和风格,由Openjdk社区维护;JDK6由Sun公司内部维护。Sun公司JDK6的很多技术来自Openjdk社区,由于社区的Openjdk7与JDK6代码结构有差异,因此技术的迁移产生了很多障碍; JDK6属于非常流行的Java虚拟机版本,在重重因素的驱使下,Openjdk社区在Openjdk7发展到第22个发行版的时候,从该发行版建立了另外一个分支,也就是我们现在普遍使用的Openjdk6;

3、    Openjdk6使用了与Sun JDK6统一的代码结构,并兼容Java SE 6标准,因此Sun公司的内部维护与社区的技术也就实现了很方便的融合。这样,随着时间的推移,Openjdk6、Openjdk7和JDK6三个版本各自独立地发展着,也各自逐步完善起来,Openjdk6与Openjdk7开源,由Openjdk社区开发者维护,JDK6由Sun公司内部维护。其中Openjdk6继承了Openjdk7强大的功能、较高的效率以及JDK6优秀的代码风格,渐渐成为开源Java虚拟机的主流版本;

4、    Sun jdk中包含有部分第三方代码,这部分代码并没有开放,Sun只是以二进制插件的形式对开发者提供,因此Openjdk还有一部分代码是闭源的,这些代码以二进制插件的形式存在。这样,在Openjdk的基础上,逐渐成立了另外一个项目——IcedTea,IcedTea项目开放了全部的二进制插件,是全部开源的Java虚拟机版本。

兼容性

Openjdk6是sun jdk的开源版本,符合Java SE 6标准,因此与sun jdk6完全兼容。在内部实现上的类库有微小差别,用户使用上的API(应用程序接口)没有区别,因此两个平台间可以无缝迁移。使用到有差别类库的情况很少,并不能一概而论,需要在应用过程中分情况区别对待。

当时的自己并没发现是判题环境的问题,也没能及时的调整。于是在所有的裁判机器上都安装了OpenJDK。导致了后来比赛的时候有两道题不能正确的判题。对做了这两道题的同学深感抱歉。但是说的在多都是在逃避责任!还是自己知道的太少too weak!

总结本次比赛环境搭配遇到的问题以及解决的方安:

一、误用OpenJDK

出现的问题我个人认为是因为PC^2的开放搭建环境跟OpenJDK的环境漏洞还是有一定的冲突的。

解决方安:

二、比赛过程涉及网络不稳定的问题

由于计算机网络学的太菜。。。。。。。比赛时候完全跪了Orz

比赛一开始使用的是外网。老师来后当心很多同学上网查阅资料,所以要关闭了外网。但是当时IPV4使用的自动分配啊!!!!!一关就重新开始分配了IP地址,于是造成了服务器的IP地址变动。使得原先的team机的IP设置全报废了。后来,虽然老师手动配置了服务机的ip地址。但是又造成了环网络的问题。使得很多的team机连不上服务机造成了四循环的问题T_T。

解决方安:  一开始就给所有比赛的电脑手动的配置静态ip!

三、解决了网络问题team机还是连不上

当时我们用比较长的一段的时间在解决了网络不稳定后,个机子都能ping 的通了但是在某一个team序号之后的team机还是链接不上。最后,重启服务机后还是解决不了。当时差点想拆电脑的节奏。(关键是电脑也不是我的呀!)旁边的同学看了一下说为什么从只有机器的team号跟分配的team号不一样的才登不上呢?最后,我也发现了,于是立马兴奋的改过后,发现果断可以了。

解决方安:保持机器的team号跟手动分配的team号一致。(个人感觉这是pc^2的一大有待改进的地方。)

四、名次的同步和搭建

在windows系统下IE就可以直接使用。但是在Ubuntu下要下载安装apache。使得他指向scoreboard的html目录。具体方法可以参见网上的详解。还有就是只有在scoreboard的帐号登入的时候才会出现html的版。这个一开始没注意被坑了好久。。。泪流满面。。。。

五、队员的提交代码记录找不到

囧。。。。。至今不懂的在哪里可以找到。按照网路原理应该是在服务机上的,但是最后还是不知道在哪里。。。。。。

总的来说这次校赛由于题目的神秘性和难度略大,所以也给比赛环境的搭配失败带来了一次回生的机会。最后,跌跌撞撞的还是顺利结束了比赛。

从这次为校赛搭配环境中收获颇多。

1、没有什么问题是解决不了的,办法总是多于问题!

2、无论做什么事都要做好预先评估。

3、做事要提前做好准备,充不充分是另一回事。

4、当遇到问题的时候,要冷静的分析问题的所在,从外到里一层层不断的接近问题的根源。最后,除根。因为,   很多问题都不可能一下就可以发现或找到本质的解决方安。而此时我们所能做的就是一点点的剖析分解问题,把问题渐小话。最后,在统一解决。有木有感觉很像分治算法。。。。。。看来是学疯了。。囧。。。

祝:NYIST ACM越来越强大!

时间: 2024-10-06 15:52:57

2014NYIST校赛ACM-ICPC竞赛环境的配置(PC^2)总结的相关文章

Hdu 5439 Aggregated Counting (2015长春网络赛 ACM/ICPC Asia Regional Changchun Online 找规律)

题目链接: Hdu 5439 Aggregated Counting 题目描述: 刚开始给一个1,序列a是由a[i]个i组成,最后1就变成了1,2,2,3,3,4,4,4,5,5,5.......,最后问a[i]==n(i最大)时候,i最后一次出现的下标是多少? 解题思路: 问题可以转化为求a[i] == n (i最大),数列前i项的和为多少. index: 1 2 3 4 5 6 7 8 9 10 a:        1 2 2 3 3 4 4 4 5 5 可以观察出:ans[1] = 1,

Hdu 5445 Food Problem (2015长春网络赛 ACM/ICPC Asia Regional Changchun Online)

题目链接: Hdu  5445 Food Problem 题目描述: 有n种甜点,每种都有三个属性(能量,空间,数目),有m辆卡车,每种都有是三个属性(空间,花费,数目).问至少运输p能量的甜点,花费最小是多少? 解题思路: 明显可以看出是多重背包搞两次,但是数据范围太大了,背包要到2*1e6,感觉会TLe.还是呆呆的写了一发,果断超啊!然后滚回去看背包九讲课件了,看到了二进制压缩的时候,感觉可以搞这个题目.试了一下果然AC,原本物品数目是100*100,二进制压缩以后也就是100*log210

POJ 4979 海贼王之伟大航路 【状压dp】【北大ACM/ICPC竞赛训练】

该死的题让我想起来艾斯之死... 首先想到dp(i)代表从1到[i表示的这些岛屿]所花的最小时间,然后每次枚举最后一个岛屿以此缩小范围,但发现枚举了最后一个岛屿后没有办法转移,因为不知道倒数第二个岛屿是什么,随着倒数第二个岛屿的不同,时间的增加也会不同,也就是不具备[无后效性]. 因此想到再加一个参数去约束当前问题的状态,dp(i,j)代表1到[i代表的这些点]所需的最少时间,且这趟旅程的最后一个岛屿是j,这样就可转移了,每次枚举倒数第二岛屿:答案就是dp( (1<<n) -1,n ) 具体的

POJ 6048 泰国佛塔 【dfs搜索】【疯狂剪枝!】【北大ACM/ICPC竞赛训练】

1 #include<iostream> 2 #include<cmath> 3 using namespace std; 4 5 int volumn[25],minArea[25];//volumn[i]为第i层到第1层蛋糕所用最小体积 6 int ans,n,m; //minArea[i]为第i层到第1层蛋糕所用[最小侧面积] 7 int area;//当前dfs状态所需要用的表面积 8 9 int maxV(int level,int r,int h){//用level层蛋

HDU 5025 Saving Tang Monk【bfs搜索】【北大ACM/ICPC竞赛训练】

bfs的难点在于怎么去表示一个问题的状态[也就是如何去判重] 1 #include<iostream> 2 #include<queue> 3 #include<cstring> 4 #include<map> 5 using namespace std; 6 7 struct node{ 8 int r,c; 9 int keys; 10 int kill;//记录当前杀死守卫的状态 11 int d;//时间 12 bool operator <

POJ Find the Winning Move【minmax搜索+alpha-beta剪枝】【北大ACM/ICPC竞赛训练】

1 #include<iostream> 2 using namespace std; 3 4 int row,col,chess; 5 char board[5][5]; 6 7 int minSearch(int i,int j,int alpha); 8 int maxSearch(int i,int j,int beta); 9 10 11 bool check(int r,int c){ 12 if( board[r][0]==board[r][1] && board

POJ 8471 切割回文 【dp】【北大ACM/ICPC竞赛训练】

1 #include<iostream> 2 #include<vector> 3 #define INF 100000 4 using namespace std; 5 6 string s; 7 char a[1005]; 8 vector<int> hui[1005];//hui[i]里的k指 k到i组成回文 9 int dp[1005];//dp[i]代表前i个字符要切几刀 10 11 int main(){ 12 int t; cin>>t; 13

POJ 1194 Zipper 【dp】【北大ACM/ICPC竞赛训练】

现在做dp题有点感觉了,以前估计会觉得这题很难,现在觉得这是道不是很水的水题 dp[i][j]代表A里前i个加上B里前j个能不能组成C的前i+j个. 至于怎么想到的呢,n是200,有1000组数据,所以猜测要dp二维,然后很容易就想到了. 这里再考虑到C[i+j]的这个元素肯定是由A[i]或B[j]组成(即A的最末尾或B的最末尾,因为要保证原来的order) 所以这就变成了dp[i][j] = dp[i-1][j] | dp[i][j-1]  (当然这是A[i]=B[j]=C[i+j])的情况.

POJ 3436 ACM Computer Factory 【网络流】【北大ACM/ICPC竞赛训练】

我ac掉网络流的第一题! 先总结一下网络流的一些算法吧,首先是Ford-Fulkerson算法,这个算法是保证了众多网络流算法的[正确性],其他算法也是基于其[优化]得到的.Ford的算法在于引入"反向边"的概念,反向边就是反悔边,代表你给修正以前走了的边一个机会.为什么反向边是对的呢,凭空加进来一条边真的大丈夫吗,关于这个有相关正确性的证明,我也说不清楚只能直觉上去理解. 之后是Edmonds-Karp即最短增广路算法,顾名思义,每次都找到达汇点边数最少的增广路,由此避免一些特定的消