Результаты работы программы

 

Входные данные:

Первая строка abc

Длина первой строки 3

Вторая строка 1234

Длина второй строки 4

 

Выходные данные:

Результат конкатенации первой и второй строк abc1234

Длина результирующей строки 7

 

Те же самые результаты могут быть получены при запуске следующей программы, отличающейся от приведённой выше способом копирования входных строк в результирующую:

 

#include <stdio.h> //библиотека стандартного ввода-вывода

#include <string.h> //библиотека функций для работы со строками

#include <conio.h> //библиотека консольного ввода-вывода

struct string { //структура string

int length; //содержит длину

char *p; //и саму строку

};

string operator+(string s, string t) //перегрузка операции +

{

int i;

string res; //результирующая строка

res.p=new char[s.length+t.length+1];//выделим память для строки

for (i=0; i<s.length; i++)

res.p[i]=s.p[i]; //копируем первую строку

for (i=s.length; i<s.length+t.length; i++)

res.p[i]=t.p[i-s.length]; //копируем вторую строку

res.p[i]=0; //строка завершается 0

res.length=s.length+t.length; //заполняем поле структуры- //длина строки

return res;

}

 

void main()

{

string s1={3,"abc"}, s2={4,"1234"},s3; //строки s1,s2,s3

clrscr();

printf("Входные данные:",s3.p);

printf("\nПервая строка %s\n",s1.p);

printf("Длина первой строки %d\n",s1.length);

printf("Вторая строка %s\n",s2.p);

printf("Длина второй строки %d\n",s2.length);

s3=s1+s2; //используем перегруженную операцию +

printf("\nВыходные данные:\n");

printf("Результат конкатенации первой и второй строк %s\n",s3.p);

printf("Длина результирующей строки %d\n",s3.length);

//результат конкатенации s1

//s2 - "abc1234" длина - 7

}

 

 

Пример. Рассмотрим структуру, реализующую двумерный вектор. Определим для него операции суммы, разности, унарного минуса, скалярного произведения.

 

#include <stdio.h> //библиотека стандартного ввода-вывода

 

struct Vector { //структура вектора на плоскости

double x,y; //состоит из координат х и у

};

 

Vector operator+(Vector v, Vector w) //перегрузим операцию сложения

{

Vector t;

t.x=v.x+w.x; t.y=v.y+w.y; //складываются соответствующие координаты

//двух векторов

return t;

}

 

Vector operator-(Vector v, Vector w) //перегрузим операцию вычитания

{

Vector t;

t.x=v.x-w.x; t.y=v.y-w.y; //находится разность соответствующих

//координат двух векторов

return t;

}

 

Vector operator-(Vector v) //перегрузим операцию унарного минуса

{

Vector t;

t.x=-v.x; t.y=-v.y; //найдём вектор,противоположно направленный

//и имеющий ту же длину, для данного

return t;

}

double operator*(Vector v, Vector w) //перегрузим операцию умножения

{

return v.x*w.x+v.y*w.y;//найдём скалярное произведение двух векторов

}

 

int main()

{

Vector a={1,0}, b={-1,1},c,d,e;

printf ("\nВходные данные:\n");

printf ("Вектор а={%f,%f},b={%f,%f}\n",a.x,a.y,b.x,b.y);

c=a-b;

printf("\nРезультат вычитания a-b={%f,%f}",c.x,c.y); //вычитание

printf("\nРезультат скалярного произведения a*b=%f",a*b);

//произведение

d=a+b;

printf("\nРезультат сложения a+b={%f,%f}",d.x,d.y); //сложение

e=-a ;

printf("\nВектор противоположный а это вектор е={%f,%f}",e.x,e.y);

//унарный минус

}