Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <iostream>
- #include <cmath>
- #include <iomanip>
- #include <random>
- #include <algorithm>
- using namespace std;
- int countSymmetry(int n) {
- int count = 0;
- int n_copy = n;
- // визначаємо кількість значущих цифр у числі
- int len = 0;
- while (n_copy > 0) {
- n_copy /= 10;
- len++;
- }
- // рахуємо кількість пар цифр, що співпадають і розташовані симетрично відносно середини десяткового запису цього числа
- for (int i = 0; i < len / 2; i++) {
- int digit_1 = (n % (int)pow(10, i + 1)) / (int)pow(10, i);
- int digit_2 = (n % (int)pow(10, len - i)) / (int)pow(10, len - i - 1);
- if (digit_1 == digit_2) {
- count++;
- }
- }
- if (len % 2 == 1) {
- // якщо деяка цифра стоїть посередині десяткового запису, її теж треба враховувати у парі з нею самою
- count++;
- }
- return count;
- }
- int main() {
- int n;
- cin >> n;
- cout << "countSymmetry = " << countSymmetry(n);
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment