Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
#1

Строки

25.11.2010, 21:48. Просмотров 2328. Ответов 39
Метки нет (Все метки)

Всем добрый вечер!Возник вопрос по строкам.Если кому не трудно ы разбирается в этом,просьба не оставить без внимания...
1.Ввести с клавиатуры строку символов отсортировать слова в строке в лексикографическом порядке (по алфавиту).
Или же эту:
2.Ввести с клавиатуры строку символов,удалить все гласные буквы из строки.
Спасибо заранее)))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.11.2010, 21:48
Ответы с готовыми решениями:

Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки
Сгенерировать две произвольные строки и определить, является ли какое-либо...

Добавить строки, начиная со строки К1 и до строки К2, в динамический массив строк
Есть динамический массив строк. Заполняется, т.е. размер его уже известен...

Удалить строки динамической матрицы, начиная со строки К1 и до строки К2
Сформировать динамический двумерный массив, заполнить его случайными числами и...

Ввести две символьных строки. Выполнить поиск второй строки в первой и вывести номер позиции первой строки, с которой вторая строка содер-жится в ней
Ввести две символьных строки. Выполнить поиск второй строки в первой и вывести...

Вычислить длину введенной строки и вывести символы строки с четными индексами
Напишите программу, которая требует ввода строки с клавиатуры. Программа...

39
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
27.11.2010, 14:58 #21
Цитата Сообщение от silent_1991 Посмотреть сообщение
Компилятор предупреждает вас о том, что вы можете совершить логическую ошибку, посчитав, что i вложенного цикла относится к внешнему. Замените i во вложенном цикле на, скажем, k - и предупреждение пропадёт (подозреваю).
да вы правы, спасибо
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 17:59  [ТС] #22
А можно,пожалуйста,на примере этого:

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
#include <iostream.h>
#include <string.h>
#include <conio.h>
#include <assert.h>
 
void printCharacters(const char*);
int find (char*,char);
main()
 
{
char c;
char string[]="peshat simvolov stroki";
cout<<"stroka:"<<endl;
printCharacters(string);
cout<<endl<<"Dlina stroki:"<<strlen(string)<<endl;
 
cout<<endl<<endl;
cout<<"Vvedite iskomuy simvol - ";
cin>>c;
cout<<"Nomer iskomogo simvola v stroke:"<<find(string,c);
getch();
return 0;
}
void printCharacters(const char*sPtr)
{for(;*sPtr!='0';sPtr++)
cout<<*sPtr;
}
int find (char*s,char c)
{for(int i=0;i<strlen(s);i++)
if(s[i]==c)
return i;
return -1;
}
 Комментарий модератора 
Используйте теги форматирования кода!
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 18:13 #23
1. используйте выделение кода
2. не понял что значит на примере? эта программа не соответствует заданию выше, она просто выводит строку через задницу и осуществляет поиск символа в строке
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 18:23  [ТС] #24
Да,это программа вывода строки символов на экран.Просто мне нужно сделать мой вариант что-то в этом роде.С высше написанными вариантами мы ещё не знакомы...Я ввожу,а мне выдают ошибки.Вот я и прошу как-то попроще и показываю,от чего отталкиваться...тоесть,с чем мы знакомы.
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 18:37 #25
Цитата Сообщение от Настьона Посмотреть сообщение
Да,это программа вывода строки символов на экран.Просто мне нужно сделать мой вариант что-то в этом роде.С высше написанными вариантами мы ещё не знакомы...Я ввожу,а мне выдают ошибки.Вот я и прошу как-то попроще и показываю,от чего отталкиваться...тоесть,с чем мы знакомы.
в С++ у меня туговато , а в Си (я так полагаю) если резать строку на слова то без 2-ух мерного массива или массива указателей не обойдется(но можно без динамического выделения памяти)
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 18:41  [ТС] #26
Можно с массивом указателей...
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 19:18 #27
Цитата Сообщение от Настьона Посмотреть сообщение
Можно с массивом указателей...
самый простой вариант:
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
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <ctype.h>
#include <string.h>
 
const char str[] = "words in line is better then from promt";
const int wCount = 8;
 
inline void cutInToWords(char* str, char** vector, short count);
inline void sort(char** str, int count);
 
int main(void)
{
 
    char* vect[wCount];
 
    char ch[128];
    strcpy(ch, str);
 
 
    // cut string to words
    cutInToWords(ch, vect, wCount);
 
    // sort array of strings
    sort(vect, wCount);
 
    system("PAUSE");
    return 0;
 
}
 
inline void cutInToWords(char* str, char** vector, short count)
{
    char **p_str;
 
    p_str = vector;
 
    if (!(*vector = strtok(str, ", ")))
        exit(1);
 
    ++vector;
    do {
        *vector = strtok('\0', ", ");
        ++vector;
    }while(vector - p_str <= count - 1);
}
 
inline void sort(char** str, int count)
{
    char* c;
    int min = 0;
 
    for (int i = 0, j = 0; i < count; ++i)
    {
        min = i;
        j = i + 1;
        if (j == count) break;
        for (int k = j; k < count; ++k)
        {
            if (strcmp(str[min], str[k]) > 0)
                min = k;
        }
 
        c = str[i];
        str[i] = str[min];
        str[min] = c;
    }
 
    for (int i = 0; i < count; ++i)
        printf("%s\n", str[i]);
 
}
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 19:31  [ТС] #28
Спасибо.Оно работает.Только нужно ввести с клавиатуры строку символов,а чтоб потом её сортировало по алфавиту...
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 19:50 #29
Цитата Сообщение от Настьона Посмотреть сообщение
Спасибо.Оно работает.Только нужно ввести с клавиатуры строку символов,а чтоб потом её сортировало по алфавиту...
фак..
надо сразу оговаривать все условия
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
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <ctype.h>
#include <string.h>
 
const int wCount = 8;
 
inline void cutInToWords(char* str, char** vector, short count);
inline void sort(char** str, int count);
 
int main(void)
{
 
    char str[128];
 
    char* vect[wCount];
 
    printf("Input string with 8 words\n");
    gets(str);
 
    // cut string to words
    cutInToWords(str, vect, wCount);
 
    // sort array of strings
    sort(vect, wCount);
 
    system("PAUSE");
    return 0;
 
}
 
inline void cutInToWords(char* str, char** vector, short count)
{
    char **p_str;
 
    p_str = vector;
 
    if (!(*vector = strtok(str, ", ")))
        exit(1);
 
    ++vector;
    do {
        *vector = strtok('\0', ", ");
        ++vector;
    }while(vector - p_str <= count - 1);
}
 
inline void sort(char** str, int count)
{
    char* c;
    int min = 0;
 
    for (int i = 0, j = 0; i < count; ++i)
    {
        min = i;
        j = i + 1;
        if (j == count) break;
        for (int k = j; k < count; ++k)
        {
            if (strcmp(str[min], str[k]) > 0)
                min = k;
        }
 
        c = str[i];
        str[i] = str[min];
        str[min] = c;
    }
 
    for (int i = 0; i < count; ++i)
    {
        printf("%s\n", str[i]);
    }
 
}
p.s: не забываем сказать "спасибо"
1
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 20:04  [ТС] #30
Вот требования выполнения задания:
Формирование, печать и обработку строк оформить в виде функции.
Ввод/вывод строк организовать с помощью функций:
• char* gets(char*s)
• int puts(char *s)
Для обработки строк использовать стандартные функции из библиотечного файла <string.h>
Функция main() должна содержать только описание строк и вызовы функций для формирования, печати и обработки строк.
...
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 20:29 #31
Цитата Сообщение от Настьона Посмотреть сообщение
Вот требования выполнения задания
так бы и сразу
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
const int wCount = 8;
char str[128];
 
inline void cutInToWords(char** vector, short count);
inline void sort(char** str, int count);
 
int main(void)
{
 
    char* vect[wCount];
 
    // cut string to words
    cutInToWords(vect, wCount);
 
    // sort array of strings
    sort(vect, wCount);
 
    system("PAUSE");
    return 0;
 
}
 
inline void cutInToWords(char** vector, short count)
{
    char **p_str;
 
    printf("Input string with 8 words\n");
    gets(str);
    p_str = vector;
 
    if (!(*vector = strtok(str, ", ")))
        exit(1);
 
    ++vector;
    do {
        *vector = strtok('\0', ", ");
        ++vector;
    }while(vector - p_str <= count - 1);
}
 
inline void sort(char** str, int count)
{
    char* c;
    int min = 0;
 
    for (int i = 0, j = 0; i < count; ++i)
    {
        min = i;
        j = i + 1;
        if (j == count) break;
        for (int k = j; k < count; ++k)
        {
            if (strcmp(str[min], str[k]) > 0)
                min = k;
        }
 
        c = str[i];
        str[i] = str[min];
        str[min] = c;
    }
 
    for (int i = 0; i < count; ++i)
        puts(*str++);
 
}
1
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 20:35  [ТС] #32
А можно помочь ещё одну с теми же требованиями.
Удалить все гласные буквы из строки.
Только можно без "vector",а то мы ещё это не учили.
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 21:06 #33
Цитата Сообщение от Настьона Посмотреть сообщение
А можно помочь ещё одну с теми же требованиями.
Удалить все гласные буквы из строки.
Только можно без "vector",а то мы ещё это не учили.
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
 
const int wCount = 8;
char str[128];
 
inline void rebuildString(void);
inline bool findChar(char ch);
 
int main(void)
{
 
    // rebuild string
    rebuildString();
 
    system("PAUSE");
    return 0;
 
}
 
inline void rebuildString(void)
{
    char str[256], re_str[256], *p_str, *p_re_str;
    p_str = str;
    p_re_str = re_str;
 
    printf("Input String\n");
    gets(p_str);
 
    while(*p_str)
    {
        if (!findChar(*p_str))
        {
            *p_re_str = *p_str;
            ++p_re_str;
        }
        ++p_str;
    };
 
    *p_re_str = '\0';
 
    puts(re_str);
 
}
 
inline bool findChar(char ch)
{
    if (ch == 'a' || ch == 'A' || ch == 'e' || ch == 'E' || ch == 'i' || ch == 'I'
        || ch == 'o' || ch == 'O' || ch == 'u' || ch == 'U' || ch == 'y'
        || ch == 'Y')
        return true;
    else return false;
}
будут спрашивать это не "Си с класами" и не "недо С++" это по стандарту С99
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 21:28  [ТС] #34
В том то и дело,что нужно в обычном с++ сделать.Преподша выи***)
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 21:32 #35
Цитата Сообщение от Настьона Посмотреть сообщение
В том то и дело,что нужно в обычном с++ сделать.Преподша выи***)
тогда уберешь заголовок
C
1
#include <stdbool.h>
и этот код не будет противоречить С89 который является подмножеством С++
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 21:37  [ТС] #36
Уже убирала.Но потом выдаёт множество ошибок и не компелирует.
0
zzed123
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 9
29.11.2010, 21:38 #37
Решить линейное неравенство посмотрите может кто поможет
0
norge_goth
62 / 62 / 13
Регистрация: 27.01.2009
Сообщений: 279
29.11.2010, 21:43 #38
Цитата Сообщение от Настьона Посмотреть сообщение
Уже убирала.Но потом выдаёт множество ошибок и не компелирует.
ты чем компилишь? наверно С89 компилером, тогда в самом конце заменить
C
1
2
return true;
    else return false;
на
C
1
2
return 1;
    else return 0;
а вообще если надо писать проги на С++ то хотябы компилпер С++-ий надо иметь

Добавлено через 1 минуту
Цитата Сообщение от zzed123 Посмотреть сообщение
Решить линейное неравенство посмотрите может кто поможет
это все чепуха, но требует времени, а его щас нету, сделаю когда освобожусь
0
zzed123
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 9
29.11.2010, 21:45 #39
буду ждать
0
Настьона
1 / 1 / 2
Регистрация: 29.05.2010
Сообщений: 57
29.11.2010, 23:40  [ТС] #40
У меня ВС31 и заставляют набирать только в нём.
0
29.11.2010, 23:40
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.11.2010, 23:40

Как первые два символа строки переставить в конец этой строки?
Собственно вопрос

Найти среднее арифметическое каждой строки матрицы и отсортировать строки по возрастанию
Дана квадратная матрица. Найти среднее арифметическое каждой строки и...

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


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

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

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