<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>https://algorist.com/algowiki_v2/index.php?action=history&amp;feed=atom&amp;title=Talk%3ADivide-TADM2E</id>
		<title>Talk:Divide-TADM2E - Revision history</title>
		<link rel="self" type="application/atom+xml" href="https://algorist.com/algowiki_v2/index.php?action=history&amp;feed=atom&amp;title=Talk%3ADivide-TADM2E"/>
		<link rel="alternate" type="text/html" href="https://algorist.com/algowiki_v2/index.php?title=Talk:Divide-TADM2E&amp;action=history"/>
		<updated>2026-04-30T22:23:38Z</updated>
		<subtitle>Revision history for this page on the wiki</subtitle>
		<generator>MediaWiki 1.28.0</generator>

	<entry>
		<id>https://algorist.com/algowiki_v2/index.php?title=Talk:Divide-TADM2E&amp;diff=724&amp;oldid=prev</id>
		<title>Tcaner: Added solution to one of the problems.</title>
		<link rel="alternate" type="text/html" href="https://algorist.com/algowiki_v2/index.php?title=Talk:Divide-TADM2E&amp;diff=724&amp;oldid=prev"/>
				<updated>2019-12-25T01:50:02Z</updated>
		
		<summary type="html">&lt;p&gt;Added solution to one of the problems.&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[TADM2E 8.17|(Solution 8.16)]]&lt;br /&gt;
&lt;br /&gt;
Solution in Java:&lt;br /&gt;
&lt;br /&gt;
public static void main(String[] args) &lt;br /&gt;
{&lt;br /&gt;
        boolean[][] bad = {&lt;br /&gt;
                {false,true,false,false,false,true},&lt;br /&gt;
                {false,true,false,true,false,true},&lt;br /&gt;
                {false,true,false,true,false,true},&lt;br /&gt;
                {false,true,false,true,false,true},&lt;br /&gt;
                {false,true,false,true,false,true},&lt;br /&gt;
                {false,false,false,true,false,false},&lt;br /&gt;
        };&lt;br /&gt;
        boolean[][] visited = new boolean[bad.length][bad.length];&lt;br /&gt;
        int[][] cost = new int[bad.length][bad.length];&lt;br /&gt;
        for (int i = 0; i &amp;lt; cost.length; i++) {&lt;br /&gt;
            for (int j = 0; j &amp;lt; cost.length; j++) {&lt;br /&gt;
                cost[i][j] = Integer.MAX_VALUE;&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
        int result = shortestPath(bad,visited,cost);&lt;br /&gt;
        System.out.println(result);&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
    private static class Point {&lt;br /&gt;
        int x, y;&lt;br /&gt;
        public Point(int x, int y) {&lt;br /&gt;
            this.x = x;&lt;br /&gt;
            this.y = y;&lt;br /&gt;
        }&lt;br /&gt;
&lt;br /&gt;
        public Point toRight() {&lt;br /&gt;
            return new Point(x+1,y);&lt;br /&gt;
        }&lt;br /&gt;
&lt;br /&gt;
        public Point toDown() {&lt;br /&gt;
            return new Point(x, y+1);&lt;br /&gt;
        }&lt;br /&gt;
&lt;br /&gt;
        public Point toLeft() {&lt;br /&gt;
            return new Point(x-1,y);&lt;br /&gt;
        }&lt;br /&gt;
&lt;br /&gt;
        public Point toUp() {&lt;br /&gt;
            return new Point(x,y-1);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
public static int shortestPath(boolean[][] bad, boolean[][] visited, int[][] cost) {&lt;br /&gt;
        int length = bad.length;&lt;br /&gt;
        if (bad[0][0] || bad[length-1][length-1]) {&lt;br /&gt;
            return -1;&lt;br /&gt;
        }&lt;br /&gt;
        ArrayList&amp;lt;Point&amp;gt; queue = new ArrayList&amp;lt;&amp;gt;();&lt;br /&gt;
        queue.add(new Point(0,0));&lt;br /&gt;
        cost[0][0] = 0;&lt;br /&gt;
        Point next = null;&lt;br /&gt;
        while (!queue.isEmpty()) {&lt;br /&gt;
            next = queue.remove(0);&lt;br /&gt;
            if (next.x == length-1 &amp;amp;&amp;amp; next.y == length-1) {&lt;br /&gt;
                return cost[next.x][next.y];&lt;br /&gt;
            }&lt;br /&gt;
            visited[next.x][next.y] = true;&lt;br /&gt;
            Point nextRight = next.toRight();&lt;br /&gt;
            if (canMoveRightFrom(next, length, bad)) {&lt;br /&gt;
                if (!visited(visited,nextRight,length)) {&lt;br /&gt;
                    queue.add(nextRight);&lt;br /&gt;
                }&lt;br /&gt;
                if (cost[nextRight.x][nextRight.y] &amp;gt; cost[next.x][next.y] + 1) {&lt;br /&gt;
                    cost[nextRight.x][nextRight.y] = cost[next.x][next.y] + 1;&lt;br /&gt;
                }&lt;br /&gt;
            }&lt;br /&gt;
            Point nextDown = next.toDown();&lt;br /&gt;
            if (canMoveDownFrom(next, length, bad)) {&lt;br /&gt;
                if (!visited(visited,nextDown,length)) {&lt;br /&gt;
                    queue.add(nextDown);&lt;br /&gt;
                }&lt;br /&gt;
                if (cost[nextDown.x][nextDown.y] &amp;gt; cost[next.x][next.y] + 1) {&lt;br /&gt;
                    cost[nextDown.x][nextDown.y] = cost[next.x][next.y] + 1;&lt;br /&gt;
                }&lt;br /&gt;
            }&lt;br /&gt;
            Point nextUp = next.toUp();&lt;br /&gt;
            if (canMoveUpFrom(next, length, bad)) {&lt;br /&gt;
                if (!visited(visited,nextUp,length)) {&lt;br /&gt;
                    queue.add(nextUp);&lt;br /&gt;
                }&lt;br /&gt;
                if (cost[nextUp.x][nextUp.y] &amp;gt; cost[next.x][next.y] + 1) {&lt;br /&gt;
                    cost[nextUp.x][nextUp.y] = cost[next.x][next.y] + 1;&lt;br /&gt;
                }&lt;br /&gt;
            }&lt;br /&gt;
            Point nextLeft = next.toLeft();&lt;br /&gt;
            if (canMoveLeftFrom(next, length, bad)) {&lt;br /&gt;
                if (!visited(visited,nextLeft,length)) {&lt;br /&gt;
                    queue.add(nextLeft);&lt;br /&gt;
                }&lt;br /&gt;
                if (cost[nextLeft.x][nextLeft.y] &amp;gt; cost[next.x][next.y] + 1) {&lt;br /&gt;
                    cost[nextLeft.x][nextLeft.y] = cost[next.x][next.y] + 1;&lt;br /&gt;
                }&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
        return -2;&lt;br /&gt;
    }&lt;/div&gt;</summary>
		<author><name>Tcaner</name></author>	</entry>

	</feed>