Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 18.01.2016
Сообщений: 4
1

Вывести все слова четной длины, у которых все буквы из первой половины слова встречаются во второй

20.01.2016, 20:03. Просмотров 1049. Ответов 1
Метки нет (Все метки)

Задача: Дана последовательность символов, состоящая из слов четной длины. Вывести на экран все слова четной длины, у которых все буквы из первой половины слова встречаются во второй половине слова, или сообщение «Нет», если требуемых слов нет.
Вот мой вариант кода. Я пытался засунуть первую и вторую половины слова в разные массива и сравнивать элементы. В итоге выводится только слово "нет", а не нужные слова. Буду благодарен за помощь.
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#include <stdio.h>
#include <stdlib.h>
#include <locale.h>
#include <string.h>
 
int main ()
{
    int n, i, j, pp=0, k, p, flag=0, flag2=0;
    char s[1000], sf[1000], s1[1000], s2[1000];
    setlocale(LC_ALL, "Russian");
    printf("Введите строку\n");
    gets(s);
    n = strlen(s);
    for (i=0; i<=n; i++)
        if ((s[i] == ' ') || (s[i]=='\0')) {
            for (j=pp; j<i; j++)
                sf[j] = s[j];
            pp = i;
            p = strlen(sf)/2;
            for (j=0; j<p; j++)
                s1[j] = sf[j];
            for (j=0; j<p; j++)
                s2[j] = sf[j+p+1];
            for (j=0; j<p; j++)
                for (k=0; k<p; k++)
                    if (s1[j] == s2[k])
                        flag++;
            if(flag == p)
                for (i=0; i<n; i++){
                    printf("%c", sf[i]);
                    flag2++; }
            memset(sf, 0, sizeof(sf) / sizeof(sf[0]));
            }
    if(!flag2)
        printf("Нет\n");
    system("Pause");
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.01.2016, 20:03
Ответы с готовыми решениями:

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

Удалить из файла все слова, длина которых меньше половины длины самого длинного слова второй строки
Переписать текст в файл output.txt, удалив из него все слова, длина которых меньше половины длины...

Распечатать все слова четной длины, в которых нет удвоенной буквы Н
уважаемые эксперты помогите пожалуйста с заданием 27.1. Дана матрица размером 6Х6 элементов,...

Строки. Вывести на экран все слова четной длины, у которых...
Дана последовательность символов, состоящая из слов четной длины. Вывести на экран все слова четной...

1
95 / 78 / 74
Регистрация: 11.05.2015
Сообщений: 189
20.01.2016, 21:59 2
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
 
int isWord(char* s)
{
    int len, i;
    int letterInFirstHalf[256] = {0};
    len = strlen(s);
    if (len%2!=0)
        return 0;
    for (i=0; i<len/2; i++)
        if (letterInFirstHalf[(int)s[i]]==0)
            letterInFirstHalf[(int)s[i]]++;
    for (i; i<len; i++)
        if (letterInFirstHalf[(int)s[i]]==1)
            letterInFirstHalf[(int)s[i]]--;
    for (i=0; i<256; i++)
        if (letterInFirstHalf[i]!=0)
            return 0;
    return 1;
}
 
int main()
{
    char *p, text[] = "1234 123125 133132 aaababcd";
    int flag = 0;
    p = strtok(text," ");
    while (p)
    {
        if (isWord(p))
        {
            puts(p);
            flag = 1;
        }
        p = strtok(0," ");
    }
    if (!flag)
        puts("No");
    system("pause");
    return 0;
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.01.2016, 21:59

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Сделать большими все буквы в тех словах, длина которых меньше половины длины самого длинного слова
программа с множествами, процедурами и функциями на turbo pascal Работать с символами и со...

Сделать большими все буквы в тех словах, длина которых меньше половины длины самого длинного слова строки
Здравствуйте,помогите пожалуйста решить Сделать большими все буквы в тех словах,длина которых...

Сделать большими все буквы в тех словах, длина которых меньше половины длины самого длинного слова строки
на Тurbo Pascal с использованием множеств, процедур и функций

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.