I need a little help, here it is:
On the planet Gliese 581 there are two nations, which fight all the
time...as soon as one of the sides is dominant in numbers, it starts
attacking the second one. On peace discussions they decided, that the
solution is splitting the population in such way, that no adjacent
cities will have the same nation in them.(In ine city there are only
inhabitants from one nation.)
In the function input there is the adjacency of cities assigned by a
list [[m11,m21],[m12,m22],...,[m1N,m2N]], where the pairs [m1i,m2i]
says, that the cities m1i and m2i are adjacent.
The function result gives TRUE, if it is possible to inhabit all
cities, else it gives FALSE.
example:
peaceAble [[1,2],[2,3],[3,5],[4,5],[10,2],[11,3],[5,6],[8,9],[7,8],
[4,7],[5,8],[8,12]] ==> True
peaceAble [[1,2],[2,3],[3,1]] ==> False
Anyone knows?
Haskell graph colouring
Page 1 of 11 Replies  3379 Views  Last Post: 25 May 2009  07:33 AM
Replies To: Haskell graph colouring
#2
Re: Haskell graph colouring
Posted 25 May 2009  07:33 AM
The pseudocode to colur a graph would be:
1. Sort the vertices in decreasing order of degree and initially have every vertex uncolored. Sorting isn't really necessary though, i left it out because I couldn't figure out how to implement an instance of Ord :$
2. Traverse the vertices in order, giving a vertex color 1 if it is uncolored and it does not yet have a neighbor with color 1.
3. Repeat this process with colors 2, 3, etc. until no vertex is uncolored.
Hi, I'm also pretty new to functional programming, but I (think) managed to solve this. Here is a bit of an outline:
 Define a data type called vertex with its name, colour (originally 1) and adjacencies.
 Write a function that will build your vertices from the list.
 The actual solving:
I wrote 3 functions  colourGraph (takes a list of uncoloured vertices and colours them); colourVertex (takes a single vertex, a list of coloured vertices, and returns the coloured vertex); canColour (takes a coloured vertex, the colour we are tyring to apply, the index where the uncoloured vertex should be in the adjacency array of the coloured vertex and returns True or False)
The idea behind colourGraph is to cons a coloured vertex onto an already coloured portion of the graph (tail recursion). Remember that colouring an empty list of vertices is an empty list.
The colourVertex function applies a colour to a vertex by trying to colour it 0, 1, 2 etc until it finds a valid colour, based on the already coloured portion of the graph. Remember that colouring a vertex given an empty coloured portion of the graph should return a vertex with colour 0. Also remember that you need to go through each vertex in the already coloured sectin to check if the uncoloured vertex can be coloured 0, if not it needs to start again by trying to colour it 1, then 2 etc (i used a utility function here to help colourVertex out  it takes the vertex we are trying to colour, the coloured portion of the graph, the coloured portion of the graph again, the colour we are trying and returns the coloured vertex). I'll leave you to think about how exactly to implement the utility function, but I'll give you a hint  I passed the coloured portion twice so that the first bit stays the same (in case i need to try more colours) and the second bit is used in the recursion).
The canColour function just checks if the adjacency array at the given index is 1 (not next to each other) or if the colour of that coloured vertex is not the same as the colour we are wishing to try.
Now all you need to do is find the vertex with the highest numbered colour (colours range from 0  order1) and see if this is 2 for a two colour graph.
Good luck!
1. Sort the vertices in decreasing order of degree and initially have every vertex uncolored. Sorting isn't really necessary though, i left it out because I couldn't figure out how to implement an instance of Ord :$
2. Traverse the vertices in order, giving a vertex color 1 if it is uncolored and it does not yet have a neighbor with color 1.
3. Repeat this process with colors 2, 3, etc. until no vertex is uncolored.
Hi, I'm also pretty new to functional programming, but I (think) managed to solve this. Here is a bit of an outline:
 Define a data type called vertex with its name, colour (originally 1) and adjacencies.
 Write a function that will build your vertices from the list.
 The actual solving:
I wrote 3 functions  colourGraph (takes a list of uncoloured vertices and colours them); colourVertex (takes a single vertex, a list of coloured vertices, and returns the coloured vertex); canColour (takes a coloured vertex, the colour we are tyring to apply, the index where the uncoloured vertex should be in the adjacency array of the coloured vertex and returns True or False)
The idea behind colourGraph is to cons a coloured vertex onto an already coloured portion of the graph (tail recursion). Remember that colouring an empty list of vertices is an empty list.
The colourVertex function applies a colour to a vertex by trying to colour it 0, 1, 2 etc until it finds a valid colour, based on the already coloured portion of the graph. Remember that colouring a vertex given an empty coloured portion of the graph should return a vertex with colour 0. Also remember that you need to go through each vertex in the already coloured sectin to check if the uncoloured vertex can be coloured 0, if not it needs to start again by trying to colour it 1, then 2 etc (i used a utility function here to help colourVertex out  it takes the vertex we are trying to colour, the coloured portion of the graph, the coloured portion of the graph again, the colour we are trying and returns the coloured vertex). I'll leave you to think about how exactly to implement the utility function, but I'll give you a hint  I passed the coloured portion twice so that the first bit stays the same (in case i need to try more colours) and the second bit is used in the recursion).
The canColour function just checks if the adjacency array at the given index is 1 (not next to each other) or if the colour of that coloured vertex is not the same as the colour we are wishing to try.
Now all you need to do is find the vertex with the highest numbered colour (colours range from 0  order1) and see if this is 2 for a two colour graph.
Good luck!
This post has been edited by blackstarzes: 25 May 2009  07:34 AM
Page 1 of 1
