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

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

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

Одномерный массив. вывод символов по заданному условию - C++

24.06.2012, 12:05. Просмотров 653. Ответов 6
Метки нет (Все метки)

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

Не могу понять, как правильно задать условие,чтобы буквы сравнились между собой и повторяющиеся не выводились в результате.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.06.2012, 12:05
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Одномерный массив. вывод символов по заданному условию (C++):

Заполнить одномерный массив, обработав данные двумерного массива по заданному условию - C++
Создать программу, которая вводит c клавиатуры двумерный массив целых чисел a, заполняет одномерный массив b - суммами отрицательных...

Матрица и одномерный массив (Составить одномерный массив, содержащий количество буквенных символов в каждом из ее столбцов, подсчет символов) - C++
Помогите решить задачку: Дана матрица 5х7, элементами которой являются значения символьного типа. Составить одномерный массив, содержащий...

Двумерный массив (преобразование масиива по заданному условию) - C++
Ввести построчно элементы двумерного массива чисел заданного размера. Вывести значенияэлементов введенного массива. Из столбцов...

Сформировать одномерный массив по условию - C++
По условию:

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

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

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Invader_Zim
Twilight Parasite
153 / 149 / 2
Регистрация: 21.07.2011
Сообщений: 908
24.06.2012, 12:51 #2
Gesta, ASCII таблица в помощь
nexus777
0 / 0 / 0
Регистрация: 24.06.2012
Сообщений: 19
24.06.2012, 13:01 #3
задача явно делится на 2 этапа:
1) надо из входного массива убрать все буквы, которые повторяются
2) сортировка массива

1) первое что приходит в голову. Создаем массив, в который будем добавлять элементы, которые не повторяются.
при el1 = 1ый элемент массива А

while( существует el1 )
{
el2 = след элемент массива А после el1;
rez = 0;
while( существует el2 и !rez)
{
if( el1 == el2 )
rez = 1;
el2 = следующий после el2 элемент;
}
if( !rez ) el1 добавить в массив B
el1 = следующий после el1 элемент
}


2) Сортировка на ваш выбор)
soon
2540 / 1305 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
24.06.2012, 13:43 #4
nexus777, задача, на самом деле, из разряда "реализуйте BST или воспользуйтесь уже имеющимся".
nexus777
0 / 0 / 0
Регистрация: 24.06.2012
Сообщений: 19
24.06.2012, 13:53 #5
я понимаю) просто я постарался объяснить задачу на том уровне, на котором был задан вопрос. А BST знаете ли не уровень с++ для новичков)))
igorrr37
1646 / 1274 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
24.06.2012, 14:12 #6
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.h>
#include <stdlib.h>
 
int Compare(const void* p1, const void* p2)
{
    return *(const char*)p1 - *(const char*)p2;
}
 
int main()
{
    char arr[] = "cfgbfgn", *pa(nullptr), *pb(nullptr);
    size_t const size = strlen(arr);
    qsort(arr, size, sizeof(*arr), Compare);
    for(pa = arr; *(pb = pa); )
    {
        while(*pa == *pb) ++pa;
        if(1 == pa - pb) std::cout << *pb;
    }
    return 0;
}
David Sylva
1285 / 947 / 51
Регистрация: 17.05.2012
Сообщений: 2,687
24.06.2012, 14:52 #7
Наверное не лучший вариант, но так сделать можно


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
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
 
bool myfunc(int i, int j) 
{ 
    return ( i == j); 
} 
 
int main() 
{ 
    char str[] = "asdasdasfasgfdfas"; 
    int size = strlen(str); 
 
    vector<char> vec(str, str+size); 
    vector<char> ::iterator it;
 
    it = unique_copy(str, str+size,vec.begin());
 
    sort(vec.begin(), it); 
 
    it = unique_copy(vec.begin(), it, vec.begin(), myfunc); 
 
    vec.resize(it - vec.begin()); 
 
    for ( it = vec.begin(); it!= vec.end(); it++) 
        cout << *it << " "; 
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.06.2012, 14:52
Привет! Вот еще темы с ответами:

Сформировать одномерный массив из элементов матрицы по условию - C++
помогите плз, решить задачу в программировании ноль Дана матрица K(m,n).Сформировать одномерный массив L(m),элементами которого являются...

Обработать одномерный массив согласно условию задачи - C++
В одномерном массиве, состоящем из n целых элементов, вычислить: 1) номер максимального элемента массива; 2) произведение элементов...

Одномерный массив, найти сумму элементов по условию - C++
: В заданном целочисленном массиве Z(15) положительных, отрицательных и нулевых чисел определить сумму и вывести последовательность...

Обработать одномерный массив согласно условию задачи - C++
Доброго времени суток. Не могли бы вы мне помочь написать программу в С++, буду очень благодарен, вот задания : В одномерном массиве,...


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

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

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