найти ошибку в коде (СИ), нужно отобрать в другой массив все числа, у которых вторая с конца
цифра (число десятков) – ноль.
#include
#include
#include
#include
using namespace std;
int s[10],i,n,k,t[10],j;
main(){
setlocale(LC_ALL,"RU");
srand(time(NULL));
printf("массив:");
for (int i = 0; i < 10; i++){
s[i] = (rand() % 100+1);
printf("%d ", s[i]);}
j=-1;
for(i=0;i k=s[i]/10;
if(k%10==0){ j++; t[j]=s[i];}}
if(j==-1)
printf("Нет такого числа");
else for(i=0;i<=j;i++)
printf("%3d",t[i]);
}
Приведём все степени к основанию 2
2^3702-2^468+2^1620-108
-108 можно представить как -128 + 16 + 4
2^3702-2^468+2^1620-2^7 + 2^4 + 2^2
Теперь выстраиваем степени в порядке убывания:
2^3702+2^1620-2^468-2^7 + 2^4 + 2^2
В выражении два вычитания подряд, избавимся от этого, заменив -2^468 на -2^469 + 2^468
2^3702+2^1620 -2^469+2^468-2^7 + 2^4 + 2^2
2^3702 - 1 единица
2^4 - 1 единица
2^2 - 1 единица
Количество единиц в вычитаниях будет равно разнице степеней. Например 1000000-100=1111
2^1620 -2^469 - количеств единиц 1620-469 = 1151
2^468-2^7 - количество единиц 468-7 = 461
Общее количество единиц равно 3+1151+461 = 1615