您的位置:首页 > 其它

flex 比较二维二元数组是否有重复(包括交集) 例如ip范围的例子

2010-08-27 11:07 295 查看
<?xml version="1.0" encoding="utf-8"?>

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"

layout="absolute" creationComplete="init()">

<mx:Script>

<![CDATA[

import mx.controls.Alert;

private function init():void {

var array:Array = [

[-3, 0],

[-1,-7]

]

var flag:Boolean = isRepeat(array);

if (flag == true) {

Alert.show('重复');

} else {

Alert.show('没有重复');

}

}

protected function isRepeat(array:Array):Boolean {

var flag:Boolean = false;

if (array.length > 0) {

var len:uint = array.length;

if (len == 1) {

flag = false;

} else if (len > 1) {

for (var i:int=0; i<len;) {

for (var j:int=0; j<len; j++) {

if (i === j) {

continue;

} else {

if (parseInt(array[j][0]) <= parseInt(array[j][1])) {

if ((parseInt(array[i][0]) >= parseInt(array[j][0]) && parseInt(array[i][0]) <= parseInt(array[j][1]))

||(parseInt(array[i][1]) >= parseInt(array[j][0]) && parseInt(array[i][1])<= parseInt(array[j][1]))) {

flag = true;

return flag;

} else {

flag = false;

}

} else if (parseInt(array[j][0]) > parseInt(array[j][1])) {

if ((parseInt(array[i][0]) >= parseInt(array[j][1]) && parseInt(array[i][0]) <= parseInt(array[j][0]))

||(parseInt(array[i][1]) >= parseInt(array[j][1]) && parseInt(array[i][1])<= parseInt(array[j][0]))) {

flag = true;

return flag;

} else {

flag = false;

}

}

}

}

i++;

}

}

}

return flag;

}

]]>

</mx:Script>

</mx:Application>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐