Advertisement
Josif_tepe

Untitled

Feb 3rd, 2025
49
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.25 KB | None | 0 0
  1. #include <iostream>
  2. #include <queue>
  3. #include <vector>
  4. #include <algorithm>
  5. using namespace std;
  6. int main(){
  7.     int S, E;
  8.     cin >> S >> E;
  9.    
  10.     vector<int> palindromes;
  11.     for(int i = 1; i <= 100000; i++) {
  12.         int tmp = i;
  13.         int reverse_number = 0;
  14.         while(tmp > 0) {
  15.             int cifra = tmp % 10;
  16.             reverse_number = (reverse_number * 10) + cifra;
  17.             tmp /= 10;
  18.         }
  19.        
  20.         if(reverse_number == i) {
  21.             palindromes.push_back(i);
  22.         }
  23.     }
  24.    
  25.     queue<int> q;
  26.     q.push(S);
  27.     q.push(0);
  28.     vector<bool> visited(100000, false);
  29.    
  30.     while(!q.empty()) {
  31.         int c_number = q.front();
  32.         q.pop();
  33.         int cnt = q.front();
  34.         q.pop();
  35.        
  36.         if(c_number == E) {
  37.             cout << cnt << endl;
  38.             break;
  39.         }
  40.        
  41.         for(int i = 0; i < palindromes.size(); i++) {
  42.             if(palindromes[i] < c_number and c_number + palindromes[i] <= E and !visited[c_number + palindromes[i]]) {
  43.                
  44.                 q.push(c_number + palindromes[i]);
  45.                 q.push(cnt + 1);
  46.                 visited[c_number + palindromes[i]] = true;
  47.             }
  48.         }
  49.     }
  50.     return 0;
  51. }
  52.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement