dengxinyi 7 gadi atpakaļ
vecāks
revīzija
884f7fd898
2 mainītis faili ar 79 papildinājumiem un 4 dzēšanām
  1. 70 4
      hard/149.go
  2. 9 0
      hard/154.go

+ 70 - 4
hard/149.go

@@ -1,5 +1,12 @@
 package main
 
+// Tuple3Int ...
+type Tuple3Int struct {
+	_1 int
+	_2 int
+	_3 int
+}
+
 /**
  * Definition for a point.
  * type Point struct {
@@ -7,10 +14,69 @@ package main
  *     Y int
  * }
  */
-func maxPoints(points []Point) int {
-	return 0
+func maxPoints(points []Point) (maxPts int) {
+	xAxisDir := make(map[int]int)
+	yAxisDir := make(map[int]int)
+	weight := make(map[Point]int)
+	for i := range points {
+		xAxisDir[points[i].X]++
+		yAxisDir[points[i].Y]++
+		weight[points[i]]++
+	}
+	lines := make(map[Tuple3Int]map[Point]int)
+	for i := 0; i < len(points); i++ {
+		for j := i + 1; j < len(points); j++ {
+			if points[i].X != points[j].X && points[i].Y != points[j].Y {
+				pair := getParamsOfLine(points[i], points[j])
+				if _, ok := lines[pair]; !ok {
+					lines[pair] = make(map[Point]int)
+				}
+				if _, ok := lines[pair][points[i]]; !ok {
+					lines[pair][points[i]] += weight[points[i]]
+				}
+				if _, ok := lines[pair][points[j]]; !ok {
+					lines[pair][points[j]] += weight[points[j]]
+				}
+			}
+		}
+	}
+	for _, v := range xAxisDir {
+		if v > maxPts {
+			maxPts = v
+		}
+	}
+	for _, v := range yAxisDir {
+		if v > maxPts {
+			maxPts = v
+		}
+	}
+	for _, m := range lines {
+		pts := 0
+		for _, v := range m {
+			pts += v
+		}
+		if pts > maxPts {
+			maxPts = pts
+		}
+	}
+	return
 }
 
-func main() {
-
+// Caculate params of given line ay = bx + c, return Tuple3Int{a, b, c}
+func getParamsOfLine(p1, p2 Point) Tuple3Int {
+	y, x := p2.Y-p1.Y, p2.X-p1.X
+	a, b := x, y
+	for b != 0 {
+		a, b = b, a%b
+	}
+	return Tuple3Int{x / a, y / a, (x*p1.Y - y*p1.X) / a}
 }
+
+// func main() {
+// 	println(maxPoints(
+// 		[]Point{{1, 1}, {2, 2}, {1, 1}}))
+// 	println(maxPoints(
+// 		[]Point{{1, 1}, {2, 2}, {3, 3}}))
+// 	println(maxPoints(
+// 		[]Point{{1, 1}, {3, 2}, {5, 3}, {4, 1}, {2, 3}, {1, 4}}))
+// }

+ 9 - 0
hard/154.go

@@ -0,0 +1,9 @@
+package main
+
+func findMin(nums []int) int {
+	return 0
+}
+
+func main() {
+
+}