Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/41: Рейтинг темы: голосов - 41, средняя оценка - 4.85
0 / 0 / 0
Регистрация: 13.10.2011
Сообщений: 11

Поменять местами первое и второе слово строки

29.10.2011, 21:37. Показов 7857. Ответов 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
#include <stdio.h>
#include <conio.h>
#include <string.h>
int main()
{
    char a[100],b[20];
    int i,j=0;
    gets(a);
    for (i=0;i<strlen(a);i++)
        if (a[i]==' ')
        {
            b[j]=i;      //cоздаю масив с порядковыми номерами пробелов
            j++;
        }
    for (i=b[0]+1;i<=b[1];i++)
        printf("%c",a[i]);      //вывожу второе слово
    for (i=0;i<=b[0];i++)
        printf("%c",a[i]);     //вывожу 1 слово
    for (i=b[1]+1;i<strlen(a);i++)
        printf("%c",a[i]);         //вывожу строку без первых двух слов
    getch();
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.10.2011, 21:37
Ответы с готовыми решениями:

Поменять местами первое и последнее слово строки, если слова разделены пробелами
есть вот это, но что то помоему это не на с++ #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; #include &lt;string.h&gt; #include...

Как поменять местами первое слово первой строки с предпоследним словом второй?
У меня получается только с сделать эти же действия, но в одной строке

Поменять местами первое и второе число в файле
Нельзя использовать другие массивы и файлы. Интересует конкретно сама замена чисел, т.е. каким образом это можно сделать(в массиве...

7
33 / 32 / 7
Регистрация: 13.12.2010
Сообщений: 342
29.10.2011, 22:10
Можно разбить строку на массив строк
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
const int SIZE = 100;
    char *ch = new char[SIZE];
    cout << "Vvedite stroku ";
    gets(ch);
 
    char *x[SIZE] = {0};
    char *p = strtok(ch, " ");
    int i = 0;
 
    while(p)
    {
        x[i++] = p;
        p = strtok(NULL, " ");
    }
1
0 / 0 / 0
Регистрация: 13.10.2011
Сообщений: 11
29.10.2011, 22:37  [ТС]
ViT(Vet@l), Спасибо
Я хочу спросить вас по strtok.Можно сделать чтобы эта команда результат выводила не в столбец, а в одной строке?
0
33 / 32 / 7
Регистрация: 13.12.2010
Сообщений: 342
29.10.2011, 23:02
Эта команда функция не выводит. Почитайте

А вывести можно так:

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
#include <stdio.h>
#include <string.h>
 
using namespace std;
 
int main()
{
    const int SIZE = 100;
    char *ch = new char[SIZE];
    cout << "Vvedite stroku ";
    gets(ch);
 
    char *x[SIZE] = {0};
    char *p = strtok(ch, " ");
    int i = 0;
 
    while(p)
    {
        x[i++] = p;
        p = strtok(NULL, " ");
    }
 
    i = 0;
    while(x[i] != 0)
    {
        cout << x[i++] << " ";
    }
 
    return 0;
}
1
237 / 210 / 29
Регистрация: 08.06.2011
Сообщений: 467
29.10.2011, 23: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
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
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <ctype.h>
 
#define MAXWORDS  100
#define MAXLINE  1000
#define DELIM  " .,:;(){}\"\n\t!?"
#define swap(t, a, b) { t temp = (a); (a) = (b); (b) = temp; }
 
char *make_format(char *);
char *make_str(char *, char *, char **);
 
int main()
{
    char line[MAXLINE], *p;
    char *words[MAXWORDS], **w = words;
    char *format;
    int n1, n2;
 
    while (printf("enter a line: ") && fgets(line, MAXLINE, stdin)
        && line[0] != '\n') {
        make_format(format = strdup(line));
        for (p = strtok(line, DELIM); p != NULL; p = strtok(NULL, DELIM))
            *w++ = strdup(p);
        *w = NULL;
        n1 = n2 = 0;
        while (printf("enter a numbers of words to exchange: ")
                && scanf("%d %d", &n1, &n2) == 2) { /* format: n1<space>n2 */
            getchar();         /* skip a newline */
            if (n1 <= 0 || n1 > w - words
                || n2 <= 0 || n2 > w - words) {
                    printf("incorrect numbers!\n");
                    continue;
            } else
                break;
        }
        swap(char *, words[n1 - 1], words[n2 - 1]);
        printf("%s", make_str(line, format, words));
    }
    for (w = words; *w != NULL; w++)
        free(*w);
    free(format);
    return 0;
}
 
char *make_format(char *s)
{
    char *t, *k, *ret = s;
    int shift;
 
    for ( ; *s != '\0'; s++) {
        if (!isalnum(*s) && *s != '\'')
            continue;
        for (shift = 0, t = s + 1; isalnum(*t) || *t == '\''; t++)
            shift++;
        for (t--; ; t++) {
            *(t - shift) = *t;
            if (*t == '\0')
                break;
        }
    }
    return ret;
}
 
char *make_str(char *s, char *f, char **words)
{
    char *ret = s;
 
    for (*s = '\0'; *f != '\0'; f++)
        if (isalnum(*f) || *f == '\'') {
            if (*words != NULL) {
                strcat(s, *words);
                s += strlen(*words++);
            } else {
                strcat(s, f);
                return ret;
            }
        } else {
            *s++ = *f;
            *s = '\0';
        }
    return ret;
}
пример работы
enter a line: Hey see, what do you you?
enter a numbers of words to exchange: 6 2
Hey you, what do you see?
enter a line:
Press any key to continue . . .
1
0 / 0 / 0
Регистрация: 13.10.2011
Сообщений: 11
29.10.2011, 23:41  [ТС]
Net_Wanderer,Спасибо большое)
0
237 / 210 / 29
Регистрация: 08.06.2011
Сообщений: 467
30.10.2011, 00:11
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Поправил немного, утечка памяти была.
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
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <ctype.h>
 
#define MAXWORDS  100
#define MAXLINE  1000
#define DELIM  " .,:;(){}\"\n\t!?"
#define swap(t, a, b) { t temp = (a); (a) = (b); (b) = temp; }
 
char *make_format(char *);
char *make_str(char *, char *, char **);
 
int main()
{
    char line[MAXLINE], *p;
    char *words[MAXWORDS], **w;
    char *format;
    int n1, n2;
 
    while (printf("enter a line: ") && fgets(line, MAXLINE, stdin)
        && line[0] != '\n') {
        make_format(format = strdup(line));
        w = words;
        for (p = strtok(line, DELIM); p != NULL; p = strtok(NULL, DELIM))
            *w++ = strdup(p);
        *w = NULL;
        n1 = n2 = 0;
        while (printf("enter a numbers of words to exchange: ")
                && scanf("%d %d", &n1, &n2) == 2) { /* format: n1<space>n2 */
            getchar();         /* skip a newline */
            if (n1 <= 0 || n1 > w - words
                || n2 <= 0 || n2 > w - words) {
                    printf("incorrect numbers!\n");
                    continue;
            } else
                break;
        }
        swap(char *, words[n1 - 1], words[n2 - 1]);
        printf("%s", make_str(line, format, words));
        for (w = words; *w != NULL; w++)
            free(*w);
        free(format);
    }
    return 0;
}
 
char *make_format(char *s)
{
    char *t, *k, *ret = s;
    int shift;
 
    for ( ; *s != '\0'; s++) {
        if (!isalnum(*s) && *s != '\'')
            continue;
        for (shift = 0, t = s + 1; isalnum(*t) || *t == '\''; t++)
            shift++;
        for (t--; ; t++) {
            *(t - shift) = *t;
            if (*t == '\0')
                break;
        }
    }
    return ret;
}
 
char *make_str(char *s, char *f, char **words)
{
    char *ret = s;
 
    for (*s = '\0'; *f != '\0'; f++)
        if (isalnum(*f) || *f == '\'') {
            if (*words != NULL) {
                strcat(s, *words);
                s += strlen(*words++);
            } else {
                strcat(s, f);
                return ret;
            }
        } else {
            *s++ = *f;
            *s = '\0';
        }
    return ret;
}
0
45 / 2 / 1
Регистрация: 19.08.2017
Сообщений: 86
18.04.2019, 13:06
Помогите как сделать чтобы 1 слово заменилась на 2 слова???
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.04.2019, 13:06
Помогаю со студенческими работами здесь

Дано предложение. Поменять местами его первое и последнее слово
Не знаю как записать во вторую переменную последнее слово. Помогите пожалуйста :wall: #include &lt;stdio.h&gt; #include...

Строка символов. Поменять местами первое и последнее слово в строке
Есть задание: Дана строка символов. Поменять местами первое и последнее слово в строке. На сколько я понимаю, то должен быть массив...

Дано предложение. Поменять местами его первое и последнее слово
Часть 1. Дан числовой массив. Реализовать алгоритм сортировки подсчётом. Часть 2. Дано предложение. Поменять местами его первое и...

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

Поменять местами первое и последнее слово в строке без использования указателей
Как я понял нужно использовать пробел как разделитель слов, но как это реализовать я не знаю.


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru