На бесконечном поле имеется вертикальная стена. длина стены неизвестна. от верхнего конца стены вправо отходит горизонтальная стена также неизвестной длины. робот находится в клетке, расположенной слева от нижнего края вертикальной стены. напишите для робота алгоритм, закрашивающий все клетки, расположенные левее вертикальной стены и выше горизонтальной стены и прилегающие к ним
1. Поиск подстроки в строке, возвращает порядковый номер первого символа подстроки в строке
2. Определение длины строки
3. Выбор части строки по заданным порядковым номерам символов
4. Конкатенация (объединение) строк
Нажав клавишу F1 в среде разработки, или просто порывшись в тетрадке/учебнике/книжке/пособии можно без труда найти все эти функции, и затем всего-навсего применяем строгую логику, для успешного решения вполне сойдёт на уровне рассуждений гиббона или орангутана
Впрочем, "благодаря" реформам Фурсенко, не у всех школьников ныне достижим даже уровень мышления мартышек.
ответ:
#include "stdafx.h"
#include
using namespace std;
struct complex // структура "хранения" комплексного числа
{ float re; // действительная часть
float im; // мнимая часть
};
void print( char * txt, complex x) // вывод комплексного числа
{
printf("%s=(%f,%fi)", txt, x.re, x.im);
return;
};
complex new_complex(float a, float b) // задать значение комплексному числу
{ complex temp;
temp.re=a;
temp.im=b;
return temp;
};
complex plus_complex(complex a, complex b) // сложить два комплексных чисел
{ complex temp;
temp.re=a.re+b.re;
temp.im=a.im+b.im;
return temp;
}
int main() // простая тестовая программа
{
complex z;
printf( "vvedite re и im 1 chisla: ");
cin > > z.re > > z.im;
print( "z", z); printf("\n");
complex q;
printf( "vvedite re и im 2 chisla: ");
cin > > q.re > > q.im;
print("q", q); printf("\n");
complex sum;
sum=plus_complex(z,q);
print("q+z", sum); printf("\n");
return 0;
}
0