Всё сдал! - помощь студентам онлайн Всё сдал! - помощь студентам онлайн

Реальная база готовых
студенческих работ

Узнайте стоимость индивидуальной работы!

Вы нашли то, что искали?

Вы нашли то, что искали?

Да, спасибо!

0%

Нет, пока не нашел

0%

Узнайте стоимость индивидуальной работы

это быстро и бесплатно

Получите скидку

Оформите заказ сейчас и получите скидку 100 руб.!


Найти самое длинное общее слово двух заданных предложений

Тип Реферат
Предмет Информатика
Просмотров
1645
Размер файла
26 б
Поделиться

Ознакомительный фрагмент работы:

Найти самое длинное общее слово двух заданных предложений

Цель работы: Научиться работать со строками с помощью указателей.

Задание:

Найти самое длинное общее слово двух заданных предложений.

Требования к программе:

1. Ввод и вывод как с терминала (stdio), так и из/в файл (< и >).

2. Работа со строками только через указатели.

Выполнение работы

Описание входных, выходных и промежуточных данных.

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

str1,str2 : символьный // срока 1 и строка 2

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

p : символьный // хранит в семе максимальное слово

Промежуточные данные:

st1, st2 : символьный // массив скалярных произведений

i,n,j,k : целый // границы слова в первой и во второй строке

ввод

str1,str2

I:=0; N :=0; p := “ ”;

выполнять

если (length(p) <> 0) то

вывод

иначе

вывод

Алгоритм.


Листинг программы

#include <conio.h>

#include <string.h>

#include <stdlib.h>

#include <math.h>

#include <stdio.h>

/*титульныйлист*/

void tit_list()

{

clrscr();

gotoxy(20,1);

printf("Министерство образования и науки Украины");

gotoxy(12,2);

printf("Донецкий государственный институт искусственного интеллекта");

gotoxy(31,8);

printf("Лабораторная работа №3 ");

gotoxy(35,9);

printf("по дисциплине:");

gotoxy(17,10);

printf("'Основы программирования и алгоритмические языки'");

gotoxy(50,15);

printf("Выполнил:");

gotoxy(50,16);

gotoxy(50,17);

gotoxy(50,19);

printf("Проверил: ");

gotoxy(50,20);

gotoxy(50,21);

getch();

return;

}

int cha (char char1){

if( ((char1 < -16)&&(char1 >-33)) || ((char1 < -80)&&(char1 > -129)) || ((char1 > 96)&&(char1 < 123)) || ((char1 > 64)&&(char1 < 91))){ return 1;}

else { return 0; }

}

int sravn_char (char c1,char c2){

if (abs(c1) > abs(c2)){

switch (abs(c1 - c2)){

case 32: if ( ( (c1 > -129)&&(c1 < -112) )||( (c1 > 96)&&(c1 < 123) ) ){

return 0;}

else {return -2;} break;

case 80: if ((c1 > -113)&&(c1 < -96)){

return 0;}

else {return -3;} break;

default: ;return -1;break;

}

}

else{

switch (abs(c2 - c1)){

case 0: return 0;break;

case 32: if ( ( (c2 > -129)&&(c2 < -112) )||( (c2 > 96)&&(c2 < 123) ) ){

return 0;}

else {return -2;} break;

case 80: if ((c2 > -113)&&(c2 < -96)){

return 0;}

else {return -3;} break;

default: return -1; break;

}

}

}

int main(void)

{

tit_list();

clrscr();

char *input,*name;

char *p,*bf,*buf,*str1,*str2;

int b=0,k,lev1,lev2,l1,l2,prv1,prv2;

int l,bb,v,n;

//************* ВВОД ДАННЫХ *****************************************

FILE *f = fopen("Отчет.zen","w+");

c:

clrscr();

printf("[1] Вводсклавиатурыn");

printf("[2] Ввод с файлаn");

printf("[0] Выходn");

switch (getch()){

case 49:

//************* ввод с клавиатуры ***********************

clrscr();

char fstr1[10000],fstr2[10000];

printf("ttt Введите первую строку: n");

gets(fstr1);

printf("ttt Введите вторую строку: n");

gets(fstr2);

//***************************************************************

fprintf(f,"Данные вводяться с клавиатуры n");

printf("n********************************************n");

fprintf(f,"n********************************************n");

printf("n Первая строка:n");

fprintf(f,"n Первая строка:n");

printf("%s nn",fstr1);

fprintf(f,"%s nn",fstr1);

printf(" Вторая строка:n");

fprintf(f," Вторая строка:n");

printf("%s n",fstr2);

fprintf(f,"%s n",fstr2);

printf("n********************************************n");

fprintf(f,"n********************************************n");

//************************************************************

p[0] = ' ';

//************************************************************

b = strlen(fstr1);

buf = strdup(fstr1);

buf += b;

//************************************************************

for (k=0;k<=b;k++){

buf--;

if ((*buf == ' ')||(k == b)){

buf++;

while ((cha(buf[strlen(buf)-1]) == 0)&&(strlen(buf) != 0)){

buf[strlen(buf)-1] = ' ';

}

//**************************

v = strlen(fstr2);

bf = strdup(fstr2);

bf += v;

for (n=0;n<=v;n++){

bf--;

if ((*bf == ' ')||(n == v)){

bf++;

while ((cha(bf[strlen(bf)-1]) == 0)&&(strlen(bf) != 0)){

bf[strlen(bf)-1] = ' ';

}

//************************************************************

if (strlen(buf) == strlen(bf)){

//********************* проверка отдельно каждого символа

l=-1;

do { l++;

bb = sravn_char (buf[l],bf[l]);

}while((bb == 0)&&(l < strlen(buf)-1));

//************************************************************

if ((bb == 0)&&( strlen(buf) == strlen(p))){

printf("Общее найбольшое слово :'%s'n",buf);

fprintf(f,"Общее найбольшое слово :'%s'n",buf);

}

if ((bb == 0)&&( strlen(buf) > strlen(p))){

p = strdup(buf);

}

}

//************************************************************

bf--;

*bf = ' ';

}

}

buf--;

*buf = ' ';

}

}

if (strlen(p) != 0){

printf("Общее найбольшое слово :'%s'n",p);

fprintf(f,"Общее найбольшое слово :'%s'n",p);

}

else{

printf("Общих слов в предложений нетуn");

fprintf(f,"Общих слов в предложений нетуn");

}

getch();

break;

//******************** Вводсфайла

case 50:

FILE *ff;

clrscr();

printf("Введитеимяфайла:");

do{

k=0;

lev1 = 0;

b=0;

scanf("%s",name);

printf("name = {%s}n",name);getch();

fprintf(f,"Данные читаем из файла: %sn",name);

if ((ff = fopen(name,"rt")) == NULL){printf("Cannot open output file.n");}

clrscr();

b=1;

do{

if (b == 3){b = 2; lev2 = prv1+1;}

input[0] = ' ';

fscanf(ff,"%s",input);

if (strlen(input) == 0){ b = 0;}

//************** Перваястрока ****************************

if ((b == -1)||(b == 1)){

if (b == 1){ str1 = strdup(input);b = -1;}

else {strcat(str1," ");strcat(str1,input);}

if (input[strlen(input)-1] == '.'){b = 3;prv1 = ftell(ff);}

}

//*************** Вторая строка ***************************

if ((b == 2)||(b == -2)){

if (b == 2){ str2 = strdup(input);b = -2;}

else {strcat(str2," ");strcat(str2,input);}

if (input[strlen(input)-1] == '.'){b = -3;prv2 = ftell(ff);}

}

//*********************************************************

}while((b != -3)&&(b != 0));

if (b == 0){

clrscr();

printf("tt E R R O R n В файле не имееться двух предложений!!!n Введите другое имя файла: ");

fprintf(f,"tt E R R O R n В файле не имееться двух предложений!!!n Введите другое имя файла.n ");

fclose(ff);

}

}while(b == 0);

//************************ Исходные данные

fseek(ff, 0, SEEK_SET);

clrscr();

printf("********************************************n");

fprintf(f,"n********************************************n");

printf("n Первая строка:n");

fprintf(f,"n Первая строка:n");

b=0; l1 = lev1;

do{

fseek(ff, l1, SEEK_SET);

fscanf(ff,"%s",input);

printf("%s ",input);

fprintf(f,"%s ",input);

l1= ftell(ff);

}while(l1 < prv1);

printf("nn");

fprintf(f,"nn");

printf(" Втораястрока:n");

fprintf(f," Вторая строка:n");

l2 = lev2;

do{

fseek(ff, l2, SEEK_SET);

fscanf(ff,"%s",input);

printf("%s ",input);

fprintf(f,"%s ",input);

l2= ftell(ff);

}while(l2 < prv2);

printf("nn");

fprintf(f,"nn");

getch();

//************************ алгоритм сравнения слов

fseek(ff, 0, SEEK_SET);

l1 = lev1;

//****************************************

b = 0;

p[0] = ' ';

//****************************************

k=0;

printf("********************************************n");

fprintf(f,"********************************************n");

do{

fseek(ff, l1, SEEK_SET);

fscanf(ff,"%s",buf);

l1 = ftell(ff);

l2 = lev2;

while ((cha(buf[strlen(buf)-1]) == 0)&&(strlen(buf) != 0)){

buf[strlen(buf)-1] = ' ';

}

do{

fseek(ff, l2, SEEK_SET);

fscanf(ff,"%s",bf);

l2= ftell(ff);

while ((cha(bf[strlen(bf)-1]) == 0)&&(strlen(bf) != 0)){

bf[strlen(bf)-1] = ' ';

}

if (strlen(buf) == strlen(bf)){

//********************* проверка отдельно каждого символа

l=-1;

do{ l++;

b=-1;

b = sravn_char(buf[l],bf[l]);

}while((b == 0)&&(l < strlen(buf)-1));

//************************ выводрезультатапрверки

if ((b == 0)&&( strlen(buf) == strlen(p))){

printf("Общее найбольшое слово :'%s'n",buf);

fprintf(f,"Общее найбольшое слово :'%s'n",buf);

}

if ((b == 0)&&( strlen(buf) > strlen(p))){

p = strdup(buf);

}

}

}while(l2 < prv2);

}while(l1 < prv1);

if (strlen(p) != 0){

printf("Общее найбольшое слово :'%s'n",p);

fprintf(f,"Общее найбольшое слово :'%s'n",p);

}

else{

printf("Общих слов в предложениях нетn");

fprintf(f,"Общих слов в предложениях нетn");

}

fclose(f);

getch();

break;

//************************************************************

case 48: clrscr(); exit(1);

default: goto c;

}

//*********************** КОНЕЦ ************************

return 0;

}

Тестовые примеры.

TEST № 1

Данные берем из файла: q.txt

********************************************

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

I have many green apples

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

I have many green bananas

********************************************

Общее наибольшее слово :' green'

TEST № 2:

Данные вводятся с клавиатуры.

********************************************

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

I learn in the Institute of Artificial Intelligence

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

My friend didn’t learn in the Institute of Artificial Intelligence

********************************************

Общее наибольшее слово:' Intelligence’


Выводы: в ходе данной лабораторной работы я изучил элементарную работу со строками, создание и открытие файлов, а также непосредственное использование указателей для нахождения нужной информации в память.


Нет нужной работы в каталоге?

Сделайте индивидуальный заказ на нашем сервисе. Там эксперты помогают с учебой без посредников Разместите задание – сайт бесплатно отправит его исполнителя, и они предложат цены.

Цены ниже, чем в агентствах и у конкурентов

Вы работаете с экспертами напрямую. Поэтому стоимость работ приятно вас удивит

Бесплатные доработки и консультации

Исполнитель внесет нужные правки в работу по вашему требованию без доплат. Корректировки в максимально короткие сроки

Гарантируем возврат

Если работа вас не устроит – мы вернем 100% суммы заказа

Техподдержка 7 дней в неделю

Наши менеджеры всегда на связи и оперативно решат любую проблему

Строгий отбор экспертов

К работе допускаются только проверенные специалисты с высшим образованием. Проверяем диплом на оценки «хорошо» и «отлично»

1 000 +
Новых работ ежедневно
computer

Требуются доработки?
Они включены в стоимость работы

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

avatar
Математика
История
Экономика
icon
159599
рейтинг
icon
3275
работ сдано
icon
1404
отзывов
avatar
Математика
Физика
История
icon
156804
рейтинг
icon
6076
работ сдано
icon
2739
отзывов
avatar
Химия
Экономика
Биология
icon
105734
рейтинг
icon
2110
работ сдано
icon
1318
отзывов
avatar
Высшая математика
Информатика
Геодезия
icon
62710
рейтинг
icon
1046
работ сдано
icon
598
отзывов
Отзывы студентов о нашей работе
65 651 оценка star star star star star
среднее 4.9 из 5
Филиал "Стрела" МАИ
Спасибо большое за выполненную работу в короткий срок, все что было написано все по теме, ...
star star star star star
Ивгпу
Супер быстро и четко выполнен реферат. Даны рекомендации + объем больше заказанного
star star star star star
КГТУ
Алексей, выполнил работу очень быстро минут за 30, что очень порадовало, отличная работа,с...
star star star star star

Последние размещённые задания

Ежедневно эксперты готовы работать над 1000 заданиями. Контролируйте процесс написания работы в режиме онлайн

Написать курсовую

Курсовая, Основания и фундаменты

Срок сдачи к 12 апр.

только что

налоги и их роль в развитии страны

Отчет по практике, Налоги

Срок сдачи к 6 апр.

9 минут назад

Решить 6 задач

Контрольная, Диагностика в технических системах, информатика

Срок сдачи к 10 апр.

9 минут назад

Провозглашение приговора

Реферат, Постановление приговоров

Срок сдачи к 3 апр.

9 минут назад

Написать курсовую работу ро теме "Стохастический градиентный спуск в обучении линейных моделей"

Курсовая, Математические основы машинного обучения

Срок сдачи к 16 мая

10 минут назад

Решить все темы и тесты

Курсовая, Химия

Срок сдачи к 9 апр.

12 минут назад

Расчет npv, irr.

Другое, Менеджмент

Срок сдачи к 4 апр.

12 минут назад

анализ финансового состояния

Диплом, Бухгалтерская и налоговая отчетность

Срок сдачи к 3 мая

12 минут назад

Практика в организации

Отчет по практике, экономика и управление на предприятии

Срок сдачи к 8 апр.

12 минут назад

Постерный доклад.

Доклад, Фтизиатрия, медицина

Срок сдачи к 4 апр.

12 минут назад

Написать курсовую работу

Курсовая, Теория государства и права

Срок сдачи к 15 апр.

12 минут назад

Выполнить 9-ый вариант в методичке

Контрольная, Экономика

Срок сдачи к 4 апр.

12 минут назад

Выполнить 4 лабораторные работы

Лабораторная, Материаловедение. технология конструкционных материалов

Срок сдачи к 6 апр.

12 минут назад

Составить схему

Контрольная, Пневмоприводы, инженерия

Срок сдачи к 10 апр.

12 минут назад

Практическое задание по модулю «предпринимательство»

Другое, Производственный менеджмент

Срок сдачи к 11 апр.

12 минут назад

Сделать презентацию и опорный конспект к ней.

Другое, Криминалистика

Срок сдачи к 8 апр.

12 минут назад
12 минут назад
planes planes
Закажи индивидуальную работу за 1 минуту!

Размещенные на сайт контрольные, курсовые и иные категории работ (далее — Работы) и их содержимое предназначены исключительно для ознакомления, без целей коммерческого использования. Все права в отношении Работ и их содержимого принадлежат их законным правообладателям. Любое их использование возможно лишь с согласия законных правообладателей. Администрация сайта не несет ответственности за возможный вред и/или убытки, возникшие в связи с использованием Работ и их содержимого.

«Всё сдал!» — безопасный онлайн-сервис с проверенными экспертами

Используя «Свежую базу РГСР», вы принимаете пользовательское соглашение
и политику обработки персональных данных
Сайт работает по московскому времени:

Вход
Регистрация или
Не нашли, что искали?

Заполните форму и узнайте цену на индивидуальную работу!

Файлы (при наличии)

    это быстро и бесплатно