The problem is your data. %5% literally means <zero or more characters>5<zero or more characters>.
You could edit the first query to exclude results that are not valid such as;
SELECT * FROM table WHERE RoomNo LIKE '%5%' and RoomNo NOT LIKE '%15%'
But this is inefficient and would require you to enter every other value that you do not want but still includes a 5. The number of exclusions is determined by the number of possible characters, if you are talking about numbers only then you would have 20 - see below;
05, 15, 25, 35, 45, 55, 65, 75, 85, 95
50, 51, 52, 53, 54, 55, 56, 57, 58, 59
If you also had the possibility of characters a-z then you would have 52 exceptions.
Additionally my understanding of the function FIND_IN_SET does not work the way you are using it. It returns the position in a string, not the position in a table - refer to the below link for documentation.
http://www.w3resource.com/mysql/string-functions/mysql-find_in_set-function.php[
^]