亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? edge.java

?? java算法大全
?? JAVA
字號:
/*Edge class*/import java.awt.*;import java.io.*;import java.util.*;import java.lang.*;public class Edge implements ClassInterface{	//Variable declarations	Arrow arrow_head, arrow_head_1;	Node start, end, representative;	int start_node, end_node;		double value;	int index;	int end_x;   int end_y;	static final double CR_RATIO = 0.9;  //0.605; 	static final int Self = -1;	Color value_colour, arc_colour, arrow_colour;	boolean show_cost = false;		//method declarations   public Edge( Node start, Node end, int value ) {			this.start = start;		this.end = end;		this.value = value;		index = 0;		end_x = 0;		end_y = 0;		value_colour = Color.red;		arc_colour = Color.black;			arrow_colour = arc_colour;    	}	public boolean New( ) {		if (start.Rep().Get_ID() == -1 && end.Rep().Get_ID() == -1) {			Set_Rep( start ); 				return true;			}		else			return false;		}		public boolean Is_From( ) {		System.out.println("Edge, is_from: from "+start.Get_ID()+", end "+end.Get_ID()+", "+start.Rep().Get_ID()+", "+end.Rep().Get_ID());		if (start.Rep().Get_ID() != -1 && end.Rep().Get_ID() == -1) {			Set_Rep( start.Rep() );			return true;			}		else			return false;		}		public boolean Is_To( ) {		System.out.println("Edge, is_to: from "+start.Get_ID()+", end "+end.Get_ID()+", "+start.Rep().Get_ID()+", "+end.Rep().Get_ID());		if (start.Rep().Get_ID() == -1 && end.Rep().Get_ID() != -1) {			Set_Rep( end.Rep() );			return true;			}		else			return false;		}	public boolean Join( ) {		System.out.println("Edge, join: from "+start.Get_ID()+", end "+end.Get_ID()+", "+start.Rep().Get_ID()+", "+end.Rep().Get_ID());		if (start.Rep().Get_ID() != -1 && end.Rep().Get_ID() != -1 && start.Rep() != end.Rep() ) {			//Set_Rep( start.Rep() );			return true;			}		else			return false;		}	public Node Rep() {		return representative;		}	public void Set_Rep(Node N) {		representative = N;			start.Set_Rep(representative);		end.Set_Rep(representative);		System.out.println("updating: from = "+start.Get_ID()+", to = "+end.Get_ID()+", rep = "+representative.Get_ID());		}	public Node From_Node() {		return start;		}	public Node To_Node() {		return end;		}	public int Get_Start() {		int num;			num = start.Get_ID();		return (num);		}	public int Get_End() {		int num;			num = end.Get_ID();		return (num);		}	public double Cost() {		return value;		}	public boolean Cycle() {		if ( (start.Rep() == start.Rep()) && (end.Rep() == end.Rep()) ) return false;		else 			return start.Rep() == end.Rep();		}	public void Update_Rep() {		this.To_Node().Rep().Set_Rep( this.From_Node().Rep() );		}	public void Print_Edge( String s ) {		System.out.println( s + " .. ");		}	public void Set_Highlight(Color highlight_colour) {		this.arc_colour = highlight_colour;		this.arrow_colour = highlight_colour;		if (highlight_colour != Color.black) {			value_colour = Color.black;			}		else {			value_colour = Color.red;			}		}public void Draw_Edge( Graphics g , int num_arcs, int arrow_status) {		int start_x, start_y, end_x, end_y;		int mid_value_x, mid_value_y;		int mid_pt_x, mid_pt_y;		int x_diff, y_diff;		double distance, temp, angle, temp1;		double opp, adj, hyp, opp1, adj1;		Color node_colour;			double img_mid_x, img_mid_y;		double chord, img_dia; //for arcs		double mid_line, img_cir;		double temp3, temp4, temp5, temp6;		double img_x, img_y;		double start_angle, arc_angle, half_arc_angle;		double half_arc_angle_rad, temp_ang;		int testcase;		double img_x_e, img_y_e;		double a, b, c, gamma, alpha;		double determinant;		double numerator, denominator;		double tita;		double phi;		double yonx, xony;		double pts_array[] = new double[4];	 	int i;				//getting the scales for the node positions		double start_scale_x, start_scale_y, end_scale_x, end_scale_y;			start_scale_x = 1.00;		start_scale_y = 1.00;		end_scale_x = 1.00;		end_scale_y = 1.00;		yonx = 0.00;		xony = 0.00;		phi = 0.00;		tita = 0.00;		numerator = 0.00;			denominator = 0.00;		start_angle = 0;		arc_angle = 0;		testcase = 0;		img_mid_x = 0;		img_mid_y = 0;			img_y_e = 0.00;		img_x_e = 0.00;		opp = 0.00;		adj = 0.00;		opp1 = 0.00;		adj1 = 0.00;			determinant = 0.00;		for (i = 0; i < 4; i++) {			pts_array[i] = 0.00;			}				start_scale_x = start.Get_Scale_X();		start_scale_y = start.Get_Scale_Y();		end_scale_x = end.Get_Scale_X();		end_scale_y = end.Get_Scale_Y();			start_x = (int)((start.Mid_X())*start_scale_x);		start_y = (int)((start.Mid_Y())*start_scale_y);		end_x = (int)((end.Mid_X())*end_scale_x);		end_y = (int)((end.Mid_Y())*end_scale_y);		x_diff = end_x - start_x;			y_diff = end_y - start_y;		temp = Math.pow(x_diff,2) + Math.pow(y_diff,2);		distance = Math.sqrt(temp);		mid_pt_x = (end_x - start_x)/2 + start_x;		mid_pt_y = (end_y - start_y)/2 + start_y;					//drawing of arcs		//let the ratio between chord and imaginary radius be 2.5/4				chord = distance;		img_cir = CR_RATIO*chord;				temp3 = Math.pow((chord/2), 2);      temp4 = Math.pow(img_cir, 2);      temp5 = temp4 - temp3;      mid_line = Math.sqrt(temp5);		img_dia = 2*img_cir;			half_arc_angle_rad = Math.asin((chord/2)/img_cir);		temp6 = (half_arc_angle_rad/Math.PI)*180;		half_arc_angle = temp6;		arc_angle = 2*half_arc_angle;		temp_ang = ((90 - arc_angle)/2)*(Math.PI)/180;		hyp = img_cir;			yonx = (double)y_diff/(double)x_diff;		xony = (double)x_diff/(double)y_diff;		//new inclusion		tita = Math.atan((double)y_diff/(double)x_diff);		phi = Math.PI/2  - tita;		pts_array = Circle_Attr(x_diff, chord, mid_pt_x, mid_pt_y, mid_line, 						phi, tita, start_x, start_y, end_x, end_y);		img_mid_x = pts_array[0];		img_mid_y = pts_array[1];		testcase = (int)pts_array[2];		start_angle = Arc_Circle_Angle(pts_array[3], arc_angle, testcase);		img_x = img_mid_x - img_cir;      img_y = img_mid_y - img_cir;			g.setColor(arc_colour);			if (num_arcs != 1) {			g.setColor(arc_colour);			g.drawArc((int)img_x, (int)img_y, (int)img_dia, (int)img_dia, (int)start_angle, (int)arc_angle); 			}		else {			g.setColor(arc_colour);			g.drawLine(start_x, start_y, end_x, end_y);			}			if (arrow_status == 1) {			arrow_head = new Arrow(value_colour, value, start_x, start_y, end_x, end_y, img_mid_x, img_mid_y, img_cir, start_angle, arc_angle, arc_colour, num_arcs, mid_pt_x, mid_pt_y);			arrow_head.Draw_Arrow( g, testcase );			}		else {			if (show_cost) {				g.setColor(value_colour);				g.drawString(""+value, mid_pt_x, mid_pt_y);				}			}				}	private double Arc_Circle_Angle(double start_angle, double arc_angle, int testcase) {				switch (testcase) {					case 1: start_angle = (start_angle)*180/Math.PI;break;			case 2: start_angle = 90 - (arc_angle/2);break;			case 3: start_angle = (Math.PI/2 + start_angle)*180/Math.PI;break;			case 4: start_angle = 180 - arc_angle/2;break;			case 5: start_angle = (Math.PI + start_angle)*180/Math.PI;break;			case 6: start_angle = 270 - (arc_angle)/2;break;			case 7: start_angle = (3*Math.PI/2 + start_angle)*180/Math.PI;break;			case 8: start_angle = 360 - (arc_angle)/2;break;			default: break;			}			return start_angle;		}				private double[] Circle_Attr(int x_diff, double chord, double mid_pt_x, double mid_pt_y, double mid_line, double phi, double tita, int start_x, int start_y, int end_x, int end_y) { 		double img_mid_x, img_mid_y;		double start_angle;		int testcase, i, attr_size = 4;		double[] attr = new double[attr_size];					img_mid_x = 0.00;		img_mid_y = 0.00;		start_angle = 0.00;		testcase = 0;				for (i = 0; i < attr_size; i++) {			attr[i] = 0.00;			}					if (x_diff < 0.00) {			img_mid_x = mid_pt_x + mid_line*Math.cos(phi);			img_mid_y = mid_pt_y - mid_line*Math.sin(phi);			if (tita < 0.00) {				testcase = 7;				start_angle = Math.abs(tita) - Math.atan((chord/2)/mid_line);				}			else if (tita > 0.00) {				testcase = 5;				start_angle = Math.abs(phi) - Math.atan((chord/2)/mid_line);				}			}		else if (x_diff > 0.00) {			img_mid_x = mid_pt_x - mid_line*Math.cos(phi);			img_mid_y = mid_pt_y + mid_line*Math.sin(phi);			if (tita < 0.00) {				testcase = 3;				start_angle = Math.abs(tita) - Math.atan((chord/2)/mid_line);				}			else if (tita > 0.00) {				testcase = 1;				start_angle = Math.abs(phi) - Math.atan((chord/2)/mid_line);				}			}		if ((start_x == end_x) && (start_y > end_y)) {        	testcase = 4;			img_mid_x = start_x + mid_line;         img_mid_y = start_y - (chord/2);         }		if ((start_x == end_x) && (start_y < end_y)) {           testcase = 8;			img_mid_x = start_x - mid_line;      	img_mid_y = start_y + (chord/2);         }		if ((start_x > end_x) && (start_y == end_y)) {           testcase = 6;			img_mid_x = start_x - (chord/2);         img_mid_y = start_y - mid_line;         }		if ((start_x < end_x) && (start_y == end_y)) {           testcase = 2;			img_mid_x = start_x + (chord/2);         img_mid_y = start_y + mid_line;         }		if ((start_x == end_x) && (start_y == end_y)) {           testcase = 10;         }				attr[0] = img_mid_x;		attr[1] = img_mid_y;		attr[2] = (double)testcase;		attr[3] = start_angle;				return attr;		}	}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲丶国产丶欧美一区二区三区| 国产精品久久久久天堂| 成人免费观看视频| 免费一级片91| 亚洲另类色综合网站| 久久午夜免费电影| 欧美乱妇15p| 99这里只有久久精品视频| 黄色精品一二区| 日韩精品乱码免费| 亚洲精品高清视频在线观看| 国产三级三级三级精品8ⅰ区| 欧美日韩午夜影院| 一本一道综合狠狠老| 国产一区二区免费在线| 日本不卡一区二区三区高清视频| 亚洲欧美国产毛片在线| 欧美国产一区二区在线观看 | 欧美亚洲国产一区二区三区va| 国产一区二区三区在线观看免费视频 | 99热精品一区二区| 国产一区二区视频在线| 久久成人免费电影| 日本欧美韩国一区三区| 视频一区在线播放| 亚洲线精品一区二区三区八戒| 自拍偷自拍亚洲精品播放| 久久久777精品电影网影网| 精品成人一区二区三区四区| 欧美一区二区日韩一区二区| 678五月天丁香亚洲综合网| 欧美系列一区二区| 91福利视频久久久久| 色婷婷激情一区二区三区| 91看片淫黄大片一级| 91亚洲精华国产精华精华液| 99国产精品久| 色综合久久综合| 久久亚洲一级片| 久久亚洲一级片| 欧美激情在线观看视频免费| 国产婷婷精品av在线| 国产精品天天摸av网| 国产精品毛片无遮挡高清| 国产精品护士白丝一区av| 国产精品久久久久久久裸模| 国产精品第一页第二页第三页| 国产精品久久久久久久浪潮网站| 欧美高清在线视频| 亚洲日本免费电影| 亚洲国产欧美一区二区三区丁香婷| 亚洲综合精品久久| 日韩av中文字幕一区二区三区| 日韩高清在线电影| 国产麻豆视频一区| 99亚偷拍自图区亚洲| 欧美体内she精视频| 欧美一区二区三区四区在线观看 | 欧洲精品在线观看| 欧美精选一区二区| 精品国产免费一区二区三区四区 | 日韩免费在线观看| 国产亚洲欧美一区在线观看| 1000部国产精品成人观看| 一区二区视频在线| 日本午夜精品视频在线观看| 国产麻豆精品在线观看| 91香蕉国产在线观看软件| 欧美日韩成人综合天天影院| 欧美岛国在线观看| 国产成人精品免费| 色综合天天综合在线视频| 欧美男生操女生| 国产亚洲va综合人人澡精品| 一区二区三区四区蜜桃| 日韩av电影免费观看高清完整版 | 2020日本不卡一区二区视频| 欧美激情综合在线| 亚洲aaa精品| 国产伦精一区二区三区| 色先锋资源久久综合| 日韩天堂在线观看| 一区在线观看视频| 日韩成人av影视| 成人国产精品视频| 欧美一区二区三区在线| 国产精品视频你懂的| 午夜成人免费视频| 国产69精品久久777的优势| 欧美性色黄大片| 国产人久久人人人人爽| 五月激情丁香一区二区三区| 成人一区二区视频| 日韩欧美久久久| 亚洲一区二区三区视频在线| 国产精品77777| 欧美夫妻性生活| 亚洲精品videosex极品| 国产一区二区日韩精品| 欧美另类变人与禽xxxxx| 自拍偷拍国产亚洲| 日韩一本二本av| 亚洲精品视频免费看| 国产精品综合网| 3d成人动漫网站| 一区二区三区中文免费| 国产91精品一区二区麻豆网站| 欧美日韩成人一区| 亚洲激情自拍偷拍| av一区二区不卡| 久久综合视频网| 免费在线观看成人| 欧美日韩mp4| 亚洲麻豆国产自偷在线| 成人一道本在线| 久久久久青草大香线综合精品| 男人的j进女人的j一区| 欧美写真视频网站| 亚洲免费观看视频| 99re在线视频这里只有精品| 日本一区二区免费在线观看视频| 久久er99精品| 日韩小视频在线观看专区| 亚洲18影院在线观看| 日本精品免费观看高清观看| 综合在线观看色| 99re成人精品视频| 国产精品福利一区二区三区| 成人丝袜18视频在线观看| 久久久久久久久久久久电影 | 激情久久五月天| 日韩你懂的电影在线观看| 另类中文字幕网| 精品入口麻豆88视频| 韩国v欧美v亚洲v日本v| 久久久久久久久99精品| 国产成人在线视频网站| 欧美国产1区2区| 99re热这里只有精品视频| 亚洲天堂福利av| 欧美亚洲国产一区二区三区va| 亚洲成人av中文| 欧美猛男超大videosgay| 日韩精品91亚洲二区在线观看| 制服丝袜亚洲色图| 久久超碰97中文字幕| 久久久久久久久97黄色工厂| 成人av在线一区二区三区| 国产精品久久99| 欧美在线你懂得| 蜜桃免费网站一区二区三区| 久久久天堂av| 色综合天天综合网天天狠天天| 一个色综合网站| 欧美一区二区三区四区五区 | 国内成人免费视频| 国产精品免费久久| 欧美性受xxxx黑人xyx性爽| 人禽交欧美网站| 国产婷婷色一区二区三区四区| 97久久超碰精品国产| 亚洲成人资源网| 精品欧美黑人一区二区三区| 国产1区2区3区精品美女| 一区二区三区四区精品在线视频 | 精品国产精品一区二区夜夜嗨| 国产伦精品一区二区三区视频青涩| 国产精品拍天天在线| 欧美日韩综合色| 狠狠色丁香久久婷婷综合丁香| 国产亚洲精品超碰| 欧美视频你懂的| 国产福利一区在线| 亚洲高清中文字幕| 久久久久国产精品人| 在线精品视频小说1| 激情亚洲综合在线| 亚洲精品国产a久久久久久 | 久久久久久电影| 99国产精品视频免费观看| 奇米精品一区二区三区在线观看一| 久久精品欧美一区二区三区麻豆 | 日韩午夜电影在线观看| 成人精品视频一区二区三区尤物| 亚洲午夜久久久久久久久电影网| 精品第一国产综合精品aⅴ| 色婷婷综合视频在线观看| 奇米色一区二区三区四区| 亚洲欧美日韩在线播放| 精品国产不卡一区二区三区| 91污在线观看| 国产精品一区三区| 三级一区在线视频先锋| 中文字幕亚洲区| 26uuu亚洲| 欧美福利视频一区| 色婷婷av一区二区三区软件| 国产一区二区三区在线观看精品 | 成人精品鲁一区一区二区| 毛片av一区二区|