Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
#1

Вывести те слова из текста на экран, которые отсортированы по количеству гласных букв - C++

14.07.2015, 17:51. Просмотров 772. Ответов 20
Метки нет (Все метки)

Дали написать программу "В файле есть текст, вывести слова из текста на экран, которые отсортированы по количеству гласных букв" Работаю в Visual Studio C++. Желательно самыми простыми функциями и если можно с описанием.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.07.2015, 17:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Вывести те слова из текста на экран, которые отсортированы по количеству гласных букв (C++):

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

Вывести из текста слова с четным количеством гласных букв - C++
Вот код при компилировании выдает все правильно, но когда ввожу допустим tt ttt tttt, эти слова тоже выводятся на экран, а не должны....

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

Отсортировать слова по количеству гласных букв - C++
Помогите написать программу для Visual C++. Сам не очень разбираюсь, желательно чтобы было понятно. Сама программа "Есть файл, в файле...

Найти и вывести на экран слова, начинающиеся с гласных букв - C++
С клавиатуры задается произвольный текст, содержащий не более 5 строк, в каждой строке не более 80 символов.Найти и вывести на экран слова,...

Считать английский текст из файла и вывести на экран слова, начинающиеся с гласных букв - C++
программа , которая считает английский текст из файла и выводит на экран слова, начинающиеся с гласных букв!!! Помогите исправить...

20
Sn1p3rOk
281 / 168 / 66
Регистрация: 19.04.2014
Сообщений: 1,080
Завершенные тесты: 2
14.07.2015, 17:53 #2
Нужно написать программу. Не супер сложную
Ваши наброски где ?
0
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
14.07.2015, 17:58  [ТС] #3
Цитата Сообщение от Sn1p3rOk Посмотреть сообщение
Ваши наброски где ?
Если бы я знал как это делать, хотя бы что то, думаю не обратился бы сюда. Так что, к сожалению, нету даже набросков.
Я задавал тут недавно такой вопрос, прислали такой код.
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 <iostream>
#include <fstream>
#include <string>
#include <algorithm>
#include <vector>
using namespace std;
// функция подсчета количества гласных
int vowels(string s)
{
    string t="aeyuio";
    int count=0;
    for(size_t i=0;i<s.size();i++)
        for(size_t j=0;j<t.size();j++)
            if(s[i]==t[j])
            {
                count++;
                break;
            }
    return count;
}
// функция сравнения по количеству гласных
bool funcCompare(string s1,string s2)
{
    int n1=vowels(s1);
    int n2=vowels(s2);
    return n1<n2;
}
int main()
{
  vector<string> v;
  // вводим слова из файла file.txt
  ifstream fin("file.txt");
  string s;
  while(fin>>s)
      v.push_back(s);
  // сортируем STL алгоритмом sort в соответствии с критерием в функции funcCompare
  sort(v.begin(),v.end(),funcCompare);
  // выводим
  for(size_t i=0;i<v.size();i++)
      cout<<v[i]<<' ';
  cout<<endl;
  system("pause");
}
0
Sn1p3rOk
281 / 168 / 66
Регистрация: 19.04.2014
Сообщений: 1,080
Завершенные тесты: 2
14.07.2015, 18:05 #4
Цитата Сообщение от dfsdfgfsdg Посмотреть сообщение
Я задавал тут недавно такой вопрос, прислали такой код.
Ну и? Чем не устраивает ?
0
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
14.07.2015, 18:11  [ТС] #5
Цитата Сообщение от Sn1p3rOk Посмотреть сообщение
Ну и? Чем не устраивает ?
Извиняюсь. Я когда стал проверять, стал считать "j" за гласную, хотя в коде её нету и подумал что он не сортирует.
Если вам не сложно. Можете в этом коде сделать пояснения. Т.к. не очень пока что разбираюсь и не все команды знаю. Буду очень благодарен.
0
S_el
2109 / 1628 / 308
Регистрация: 15.12.2013
Сообщений: 6,490
14.07.2015, 18:14 #6
dfsdfgfsdg, прокомментируйте код как понимаете,а если у вас будут ошибки,мы поправим.
0
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
14.07.2015, 18:14  [ТС] #7
А можно как то заменить
"#include <algorithm>
#include <vector>"
Просто нам ещё этого не преподавали!
0
Raali
623 / 327 / 34
Регистрация: 06.07.2013
Сообщений: 1,062
Завершенные тесты: 1
14.07.2015, 18:16 #8
Цитата Сообщение от dfsdfgfsdg Посмотреть сообщение
А можно как то заменить
"#include <algorithm>
algorighm нужен для сортировки ( ф-я std::sort ), если без него, то придется сортировать вручную
0
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
14.07.2015, 18:19  [ТС] #9
Цитата Сообщение от Raali Посмотреть сообщение
algorighm нужен для сортировки ( ф-я std::sort ), если без него, то придется сортировать вручную
Нам преподаватель показывал, если я не ошибаюсь, только пузырьковый метод. Вот можно им как то заменить это?
0
S_el
2109 / 1628 / 308
Регистрация: 15.12.2013
Сообщений: 6,490
14.07.2015, 18:22 #10
Цитата Сообщение от dfsdfgfsdg Посмотреть сообщение
Просто нам ещё этого не преподавали!
Ну и что?Так вы узнаете новую информацию.И вам полезно и преподу приятно будет.

Добавлено через 19 секунд
Цитата Сообщение от dfsdfgfsdg Посмотреть сообщение
Вот можно им как то заменить это?
можно.
0
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
14.07.2015, 18:26  [ТС] #11
Цитата Сообщение от S_el Посмотреть сообщение
Вот можно им как то заменить это?
можно.
Я так думаю, заменить можно все, но я не знаю как! Вот если бы кто помог, было бы вообще супер.
0
Raali
14.07.2015, 18:28
  #12

Не по теме:

Цитата Сообщение от dfsdfgfsdg Посмотреть сообщение
Нам преподаватель показывал, если я не ошибаюсь, только пузырьковый метод.
Дело в том что нам он пузырьковый метод как раз не показывал) на практике для этого используют готовый sort

0
S_el
2109 / 1628 / 308
Регистрация: 15.12.2013
Сообщений: 6,490
14.07.2015, 18:35 #13
Цитата Сообщение от dfsdfgfsdg Посмотреть сообщение
Я так думаю, заменить можно все, но я не знаю как! Вот если бы кто помог, было бы вообще супер.
Так я вам помогаю.Предлагаю вам такой алгоритм действий:
1. Разобраться с приведенным выше кодом.
* прокомментировать,незнакомые места разобрать(использовать литературу,статьи,форум)
* задать конкретный вопрос,если что-то будет не понятно.
2. Переписать под требования преподавателя.
* выбрать замену для vector<> и sort().
* разобрать предполагаемую реализацию
* выполнить,если не получается,задать конкретный вопрос.
3. В результате получаете знания и начнете решать свои задачи самостоятельно.
0
dfsdfgfsdg
0 / 0 / 0
Регистрация: 14.07.2015
Сообщений: 16
14.07.2015, 18:38  [ТС] #14
Цитата Сообщение от S_el Посмотреть сообщение
Так я вам помогаю.Предлагаю вам такой алгоритм действий:
1. Разобраться с приведенным выше кодом.
* прокомментировать,незнакомые места разобрать(использовать литературу,статьи,форум)
* задать конкретный вопрос,если что-то будет не понятно.
2. Переписать под требования преподавателя.
* выбрать замену для vector<> и sort().
* разобрать предполагаемую реализацию
* выполнить,если не получается,задать конкретный вопрос.
3. В результате получаете знания и начнете решать свои задачи самостоятельно.
Я конечно понимаю, что можно все это все самому разобрать и понять. Но дело в том, что времени практически нету. Надо завтра программу показывать, а чтобы самому это все понять и осмыслить, знаний, на сегодняшний день, не хватает.
0
Sn1p3rOk
281 / 168 / 66
Регистрация: 19.04.2014
Сообщений: 1,080
Завершенные тесты: 2
14.07.2015, 20:06 #15
dfsdfgfsdg, вот решение. Не самый короткий, но наверное самый примитивный вариант.
Кликните здесь для просмотра всего текста
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
// Подсчет кол-ва слов в файле
int CountWords(ifstream &file)
{
    string str;
    int countWords = 0;
 
    file.open("test.txt", ios::in);
 
    while(!file.eof())
    {
        getline(file, str, ' ');
        countWords ++;
    }
 
    file.close();
 
    return countWords;
}
 
// Чтения слов из файла
void ReadFile(ifstream &file, char** words)
{
    file.open("test.txt", ios::in);
 
    int i = 0;
    char tempStr[10];
 
    while (!file.eof())
    {
        file >> tempStr;
 
        strcpy(words[i], tempStr);
 
        i ++;
    }
 
    file.close();
}
 
// Подсчет кол-ва гласных букв в каждом слове
void CountVowels(int countWords, int* countVowels, char** words)
{
    char vowels[20] = {'А', 'а', 'Я', 'я', 'О', 'о', 'Ё', 'ё', 'У', 'у', 'Ю', 'ю', 'Ы', 'ы', 'И', 'и', 'Э', 'э', 'Е', 'е' };
 
    for (int i = 0; i < countWords; i ++)
    {
        countVowels[i] = 0;
 
        for(int j = 0; j < 10; j ++)
        {
            for (int z = 0; z < 20; z ++)
            {
                if (words[i][j] == vowels[z])
                {
                    countVowels[i] ++;
                    break;
                }
            }
        }
    }
}
 
// Сортировка и вывод в консоль
void SortAndOutput(int countWords, int* countVowels, char** words)
{
    for (int i = 0; i < countWords; i ++)
    {
        for (int j = i + 1; j < countWords; j ++)
        {
            if (countVowels[i] > countVowels[j])
            {
                int temp = countVowels[i];
                countVowels[i] = countVowels[j];
                countVowels[j] = temp;
 
                char tempStr[10];
 
                strcpy(tempStr, words[i]);
                strcpy(words[i], words[j]);
                strcpy(words[j], tempStr);
            }
        }
 
        cout << "Гласных : " << countVowels[i] << " ~ " << words[i] << endl;
    }
}
 
int main()
{
    setlocale(LC_ALL, "russian");
 
    ifstream file;
    int countWords = CountWords(file);
 
    int* countVowels = new int[countWords];
 
    char** words = new char*[countWords];
    for (int i = 0; i < countWords; i ++)
    {
        words[i] = new char[10];
    }
 
    ReadFile(file, words);
 
    CountVowels(countWords, countVowels, words);
 
    SortAndOutput(countWords, countVowels, words);
 
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.07.2015, 20:06
Привет! Вот еще темы с ответами:

Строки: Вывести на экран только те слова, которые отличаются от последнего и в которых нет повторяющихся букв. - C++
вводи с клавиатуры строку. Вывести на экран только те слова, которые отлчаются от последнего и в которых нет повторяющихся букв.

Удалить слова которые содержат непарное количество гласных букв - C++
Доброе время суток форумчане. Подскажите идею решения этой задачи.

Необходимо выделить из текста слова в которых количество гласных букв парная - C++
Необходимо выделить из текста слова в которых количество гласных букв парная

Вывести на экран количество гласных букв в строке - C++
Написать программу, которая считывает текст из файла и выводит на экран количество гласных букв в строке текста


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

Или воспользуйтесь поиском по форуму:
15
Yandex
Объявления
14.07.2015, 20:06
Ответ Создать тему
Опции темы

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