मैं पाइथन के साथ Maximum Rectangle Algorithm from Dr. Dobbs (लिस्टिंग चार) को लागू करने की कोशिश कर रहा हूं। यह ज्यादातर काम करता है, लेकिन एक विशिष्ट मामला गलत परिणाम देता है और मैं यह नहीं समझ सकता कि क्यों।अधिकतम आयताकार एल्गोरिदम कार्यान्वयन
यहाँ मेरी स्रोत कोड है:
from collections import namedtuple
Point = namedtuple('Point', ('X', 'Y'))
#Y 0 1 2 X
arr = [[0, 0, 0, ], #0
[1, 0, 0, ], #1
[0, 0, 1, ], #2
]
def area(ll, ur):
if (ll.X < 0) or (ll.Y < 0) or (ur.X < 0) or (ur.Y < 0):
return 0.
return ((ur.X - ll.X) + 1) * ((ur.Y - ll.Y) + 1)
def update_cache(a, c, x):
M = len(a[0])
N = len(a)
for y in range(M):
if a[x][y] == 0:
c[y] = c[y] + 1
else:
c[y] = 0
def mrp(a):
best_ll = Point(-1, -1)
best_ur = Point(-1, -1)
M = len(a[0])
N = len(a)
c = [0 for x in range(M + 1)]
stack = []
for x in range(N-1, -1, -1):
update_cache(a, c, x)
width = 0
for y in range(M + 1):
if c[y] > width:
stack.append((y, width))
width = c[y]
if c[y] < width:
while True:
y0, w0 = stack.pop()
if (width * (y - y0)) > area(best_ll, best_ur):
best_ll = Point(x, y0)
best_ur = Point(x + width - 1, y - 1)
width = w0
if (c[y] >= width):
break
width = c[y]
if width == 0:
stack.append((y0, width))
return best_ll, best_ur
और यहाँ परिणाम है:
>>> mrp(arr)
(Point(X=0, Y=0), Point(X=1, Y=2))
आप देख सकते हैं, पहला बिंदु गलत है, लेकिन मैं समझ नहीं सकता है, जहां और क्यों यह गलत हो जाता है । तीर बदलना सही परिणाम देता है।
संपादित करें: मैंने देखा कि मैंने आलेख की तुलना में सरणी के मानों को बदल दिया है। यह update_cache में तुलना बदलता है। 0 = स्पष्ट और 1 = आरक्षित। मैं परिणाम की तलाश में हूं (प्वाइंट (एक्स = 0, वाई = 1), प्वाइंट (एक्स = 1, वाई = 2))।
संबंधित: ([सबसे बड़ा आयत एक एन × एन बाइनरी मैट्रिक्स में केवल शून्य से युक्त खोजें] http://stackoverflow.com/questions/2478447/find-largest -रेक्टंगल-युक्त-केवल-शून्य-इन-एन-एनएन-बाइनरी-मैट्रिक्स) – jfs
मैंने इस पर आधारित जावास्क्रिप्ट में और डॉ। डॉब्स लेख को लागू किया है यदि यह किसी के लिए उपयोग है: http://www.codinghands.co। ब्रिटेन/ब्लॉग/2013/02/जावास्क्रिप्ट कार्यान्वयन-OMN-अधिक से अधिक-आयत-एल्गोरिथ्म / – codinghands