1 / 1 / 0
Регистрация: 11.10.2010
Сообщений: 18
1

Найти и записать в выходной файл все симметричные слова

09.12.2012, 13:56. Показов 3941. Ответов 7
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
В произвольном тексте входного файла, содержащем не более 10 строк, в каждой строке не более 80 символов, найти и записать в выходной файл все симметричные слова.

Примечание : слова из одной буквы являются симметричными.
C++ (Qt)
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 <locale.h>
#include <conio.h>
#include <iostream>
using std::cout;
using std::cin;
#include <string.h>
int main()
{  const int N=10,M=80;
    int k, n, m, y=0, z, c, v, b, h=0, i, j;
    unsigned char a[N][M];
    setlocale(LC_ALL,"Russian");
    printf("Введите колическтво строк и символов в строке");
    scanf("%d%d", &n, &m);
    if (n <= 10 && m <= 80) //Соблюдаю условия задачи.
    {
    //  a=new unsigned char*[n];
        //for(i=0;i < m;i++)
            //a[i]=new unsigned char[m];
        for(i=0;i < n;i++)
            for(j=0;j < m;j++)
                a[i][j]=getchar(); //Заполняю массив символами.
        if ((a[0][0] == ' ') || (a[0][0] == '\n')) h=1; // Проверяю первый элемент для того, что бы можно было ставить пробел или переход на новую строку без вывода этого.
        for(i=0;i < n;i++)
            for(j=0;j <= m;j++)
            {   if ((a[i][j] == ' ') || (a[i][j] == '\n')) // Проверяю когда встречается пробел или отступ на новую строку.
            {
                for(k=(j-h)/2+1;k > 0;k--)
                        if (a[i][h+k] == a[i][j-k-1]) //Просматриваю симметричность слова.
                             y++; //Переменная количества совпадающих букв.
                    if (y > ((j-h)/2)) //Проверяю симметрию слова
                    {
                    for(k=j-h-1;k >= 0;k--) /вывожу симметричное слово.
                    std :: cout<<a[i][h+k];
                    std :: cout<<" ";
                    }
                    h=j+1;//прыгаю через пробел.
                    y=0;//обнуляю переменную количества совпадающих букв
                }
            }
            getch();
}
}
В чем суть дела:
При проверки слов:
zopol он его выводит, а не должен.
И как сделать, что бы он мог считывать русские буквы и выдавать их.
Заранее спасибо
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.12.2012, 13:56
Ответы с готовыми решениями:

Выбрать из текстового файла все симметричные слова отличные от последнего и записать их в новый файл
сформировать текстовый файл f1 выбрать из него все симметричные слова отличные от последнего и записать их в файл f2.

Записать в выходной файл построчно все ключевые слова, встречающиеся в этой программе
2. Дана программа написанная на языке Pascal. Записать в выходной файл построчно все ключевые слова, встречающиеся в этой программе, указав...

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

7
 Аватар для Ternsip
670 / 198 / 29
Регистрация: 10.05.2012
Сообщений: 595
09.12.2012, 14:08 2
Kyznec24rus, Это плохой код. Сейчас напишу свой
0
1 / 1 / 0
Регистрация: 11.10.2010
Сообщений: 18
09.12.2012, 14:13  [ТС] 3
Почему плохой:?(
0
 Аватар для Ternsip
670 / 198 / 29
Регистрация: 10.05.2012
Сообщений: 595
09.12.2012, 14:20 4
Kyznec24rus,

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <string>
 
using namespace std;
 
int main(){
    freopen("input.txt", "rt", stdin);
    freopen("output.txt", "wt", stdout);
    string str;
    while(cin >> str){
        bool check = true;
        for (int i = 0; i < str.length()/2; i++){
            if (str[i] != str[str.length()-i-1]) {
                check = false;
                break;
            }
        }
        if (check) cout << str << endl;
    }
    return 0;
}
из файла input.txt, который должен лежать в проекте рядом с запускаемым файлом, считаются все слова, проверятся на симметричность относительно середины и выведутся в файл output.txt
+ между словами может стоять сколько угодно пробелов и переводов строки

Добавлено через 3 минуты
Kyznec24rus,
C++
1
setlocale(LC_ALL,"Russian");
напишите после freopen 'ов, это подключит русские символы
1
1 / 1 / 0
Регистрация: 11.10.2010
Сообщений: 18
09.12.2012, 14:26  [ТС] 5
Опиши пожалуйста, свое логическое решение.
0
 Аватар для Ternsip
670 / 198 / 29
Регистрация: 10.05.2012
Сообщений: 595
09.12.2012, 14:34 6
Kyznec24rus, такие слова называются полиндромами http://ru.wikipedia.org/wiki/%... 0%BE%D0%BC
Я считываю из файла массив символов до тех пор пока не встретится пробел, если сначала идут пробелы, я их пропускаю (это всё делает cin >> string) затем я иду до середины слова или если кол-во символов нечётное, то округлить значение length()/2 вниз, и сравниваю симметричность

Добавлено через 1 минуту
Kyznec24rus, check - флажок, отвечающий за то, является ли слово полиндромо

Добавлено через 1 минуту
Kyznec24rus, Вы писали >> В произвольном тексте входного файла, содержащем не более 10 строк, в каждой строке не более 80 символов.
Это означает, что в файле НИКОГДА не может быть более 10 строк итп, вам не нужно проверять так ли это

Добавлено через 1 минуту
Kyznec24rus, в цикле проверки симметрии я выйду из цикла и сделаю check = false сразу после того, как увижу несовпадение
1
1 / 1 / 0
Регистрация: 11.10.2010
Сообщений: 18
09.12.2012, 14:52  [ТС] 7
То есть в while мы проверяем каждое слово? По отдельности? Правильно?
C++
1
2
3
while(cin >> str)
она равно по значению?
 if ((a[i][j] == ' ') || (a[i][j] == '\n'))
Добавлено через 4 минуты
А если нужно ввести все с клавиатуры? Программа будет продолжать работать?
Какой функцией это можно будет реализовать?
0
 Аватар для Ternsip
670 / 198 / 29
Регистрация: 10.05.2012
Сообщений: 595
09.12.2012, 14:54 8
Kyznec24rus,
C++
1
2
3
4
5
6
7
8
9
10
while(cin >> str){ //Пока считывается слово считаем СЛОВО а не всю СТРОКУ
        bool check = true; // флажок на проверку слова на симметричность
        for (int i = 0; i < str.length()/2; i++){ // идём до середины строки в цикле по i
            if (str[i] != str[str.length()-i-1]) { // если i-й символ в строке str не равен длине строки - i - 1 то  
                check = false; // меняем флажок
                break; // и выходим
            }
        }
        if (check) cout << str << endl; // выводим в файл строку если наш флажок не сменился 
    }
Добавлено через 1 минуту
Kyznec24rus, >>А если нужно ввести все с клавиатуры? Программа будет продолжать работать?
Какой функцией это можно будет реализовать?
-- Просто убрать
C++
1
2
freopen("input.txt", "rt", stdin);
freopen("output.txt", "wt", stdout);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.12.2012, 14:54
Помогаю со студенческими работами здесь

Записать в выходной файл все строки входного файла
Помогите пожалуйста, через три дня сдавать. буду очень благодарен=) Дан входной текстовый файл, строка S (вводится с клавиатуры)....

выбрать и записать в выходной файл слова по данному образцу: *#*#*, где * - согласная, а # - гласная буква
Здравствуйте) Нужно написать программа на c++ Задание: В произвольном тексте входного файла, содержащем не более 10 строк, в...

Дан входной текстовый файл, строка S (вводится с клавиатуры). Записать в выходной файл все строки входного файла, содержащие в качестве фрагмента стро
Дан входной текстовый файл, строка S (вводится с клавиатуры). Записать в выходной файл все строки входного файла, содержащие в качестве...

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

Записать в выходной файл в алфавитном порядке построчно все идентификаторы, встречающиеся в этой программе
Выполнить задания с использованием подходящих связанных динамических структур данных: Есть программа на С++. Записать в выходной файл в...


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

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

Новые блоги и статьи
Простая нейросеть на КуМир: Создание и обучение
EggHead 16.03.2025
Искусственные нейронные сети — удивительная технология, позволяющая компьютерам имитировать работу человеческого мозга. Если вы хотя бы немного интересуетесь современными технологиями, то наверняка. . .
Исполнитель Кузнечик в КуМир: Решение задач
EggHead 16.03.2025
Среди множества исполнителей в системе КуМир особое место занимает Кузнечик — простой, но невероятно полезный виртуальный персонаж, который перемещается по числовой прямой, выполняя ваши команды. На. . .
Исполнитель Водолей в КуМир: Решение задач
EggHead 16.03.2025
Разработка алгоритмического мышления — одна из ключевых задач для начинающих программистов, и система КуМир предлагает отличный способ погрузиться в этот процесс. Среди множества исполнителей в этой. . .
Исполнитель Чертежник в КуМир: Решение задач
EggHead 16.03.2025
Представьте, что вы можете рисовать на бесконечной координатной плоскости, перемещая точку, которая оставляет след. По вашей команде она может поднять перо и двигаться, не оставляя следа, или. . .
Исполнитель Робот в КуМир: Решение задач
EggHead 16.03.2025
КуМир (Комплект Учебных МИРов) — это учебная среда программирования, разработанная специально для обучения базовым концепциям алгоритмизации. Её главная фишка — использование русскоязычного. . .
Исполнитель Черепаха в КуМир: Решение задач
EggHead 16.03.2025
Представьте, что вы впервые учитесь программировать, а перед вами стоит задача заставить маленькую виртуальную черепашку рисовать на экране. Звучит забавно? Эта идея зародилась ещё в 1967 году, когда. . .
Конвейеры данных с Apache Kafka
Javaican 16.03.2025
В мире, где данные стали новой нефтью, Apache Kafka зарекомендовал себя как мощный инструмент для построения надежных и масштабируемых конвейеров данных. Созданный изначально командой LinkedIn в 2011. . .
Deno против Node.js: Будущее JavaScript рантайма
run.dev 16.03.2025
За последнее десятилетие Node. js стал абсолютным лидером среди JavaScript-рантаймов и фактическим стандартом для серверной разработки на JavaScript. Но в 2018 году тот же разработчик, который создал. . .
SwiftUI или UIKit - что выбрать для нового приложения iOS?
mobDevWorks 16.03.2025
Когда Apple представила SwiftUI на WWDC 2019, многим показалось, что дни UIKit сочтены. Новый декларативный фреймворк предлагал радикально иной подход к разработке интерфейсов. Вместо кропотливого. . .
Docker: Руководство для начинающих по созданию первого приложения
Mr. Docker 16.03.2025
Docker — это платформа, которая упаковывает ваше приложение и все его зависимости в стандартизированные блоки, называемые контейнерами. Эти контейнеры изолированы друг от друга и от основной системы,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru