O(n) time O(1) space
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 class  Solution  {public :    vector <string > findStrobogrammatic (int  n)           string  s (n, '0' )          v = {"16896891" , "018810" , "0168968910" };         dfs(s, 0 , n - 1 );         return  res;     }     void  dfs (string  &s, int  l, int  r)           if  (l > r) {             res.push_back(s);             return ;         }         int  k = 0 ;         if  (l == r) {             k = 1 ;         } else  if  (l > 0 ) {             k = 2 ;         }         for  (int  n = size(v[k]), i = 0 , j = n - 1 ; i < j; ++i, --j) {             s[l] = v[k][i];             s[r] = v[k][j];             dfs(s, l + 1 , r - 1 );         }     }     vector <string > res, v; }; 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 class  Solution  {public :    vector <string > findStrobogrammatic (int  n)           string  s (n, '0' )          vector <string > res;         find(s, 0 , n - 1 , res);         return  res;     }     void  find (string  &s, int  l, int  r, vector <string > &res)           if  (r < l) {              res.push_back(s);             return ;         }         string  chars;         if  (l == r) {              chars = "180081" ;         } else  if  (l == 0 ) {              chars = "18696981" ;         } else  {              chars = "1869006981" ;         }         for  (int  i = 0 , j = chars.length() - 1 ; i < j; ++i, --j) {             s[l] = chars[i];             s[r] = chars[j];             find(s, l + 1 , r - 1 , res);         }     } };