1. пример линейного алгоритма: решение алгебраического примера, типа: 2+ (9-5)*(3+1). план действий: 1)вычитание в скобках 2)сложение в скобках 3)умножение 4) сложение
2. пример разветвляющего алгоритма: отрывок из сказки Пушкина: "пойдет налево - песнь заводит, направо - сказку говорит" возникают две ветви в зависимости от условия. условие, например - "пойдет налево". если да, то действие - песнь заводит. если нет - то сказку говорит.
3. циклический алгоритм: наполнить стакан водой с десертной ложечки. цикл будет повторяться до тех пор, пока стакан не наполнится водой.
char num[10]; int cc; printf("Введите число и его сс: "); cin >> num >> cc;
char *pInt; int hh = strtol(num, &pInt, cc);
func(hh);
return EXIT_SUCCESS; }
void func(int num) { int c = 2; int i = 0, j = 10; int nn = num; int pr = 0;
for(; j > i; j--){ pr = nn % c; n2[j] = pr; nn /= c; }reverse(n2); }
inline void reverse(int c[1]){ int len = 11; int j = len-1; for (int i = 0; i < len; i++){}; int ber; for(int i = 0; i < len; i++) ber += c[i] * pow(10, j), j--; str(ber); }
void str(int num) { int ber = num; int c = 10; char buffer[20]; char *nm; nm = itoa(ber, buffer, c); string aa = nm; for(int i = 0; i < strlen(nm); i++){ if(nm[i] == 0 and nm[i] != nm[i+1]) for(int j = i;j;j--) aa.erase(aa.begin() + i); } int ed = 0, nu = 0; for(int i = 0; i < strlen(aa.c_str()); i++){ if(aa[i] == '1') ed++; else nu++; } cout << "Двоичная запись: " << aa << endl; printf("Количество единиц: %d\n Количество нулей: %d", ed, nu); }
Россия
Объяснение:
Белоруссия, Сент-Люсия