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

Сформировать новую строку из строк s1 и s2 так, чтобы в нее поочередно входили нечетные символы s1 и четные символы s2

20.11.2013, 23:59. Показов 1862. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание такое: сформировать новую строку из строк s1 и s2 таким образом, чтобы в нее поочередно входили нечетные символы s1 и четные символы s2. Сделать это надо двумя способами: через массивы и через библиотеку string.h. Через массивы я сделал, а вот как это реализовать через string.h не знаю...
Вот кстати как сделал через массивы.
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
#include <stdio.h>
#include <conio.h>
#include <locale.h>
#include <string.h>
 
char stroka1[256]="", stroka2[256]="", stroka3[256]=""; int i=0;
 
int main()
{
    setlocale (LC_ALL, "Rus");
    printf("Введите первую строку:");
    gets(stroka1);
    printf("Введите вторую строку:");
    gets(stroka2);
    if (strlen(stroka1) < strlen(stroka2))
        for (i=0; i<strlen(stroka2); i++)
        {if (stroka1[i]=='\0') stroka1[i]=' ';
        if (i%2==0)
            stroka3[i] = stroka1[i];
        else stroka3[i] = stroka2[i];}
    if (strlen(stroka1) >= strlen(stroka2))
        for (i=0; i<=strlen(stroka1); i++)
        {if (stroka2[i]=='\0') stroka2[i]=' ';
        if (i%2==0)
        stroka3[i] = stroka1[i];
        else stroka3[i] = stroka2[i];}
    printf ("Третья строка:");
    puts(stroka3);
    getch();
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.11.2013, 23:59
Ответы с готовыми решениями:

Сформировать строку S таким образом, чтобы в нее попеременно вошли четные символы строки S1 и нечетные символы строки S2.
Вот задание: Даны строки S1 и S2. Сформировать строку S таким образом, чтобы в нее попеременно вошли четные символы строки S1 и...

Сформировать новую строку, включив в неё 1, 3, 5, и т.д. нечётные слова
помогите написать программу в делфи

Вывести на экран в первой строке нечетные символы, во второй четные символы исходной строки
Помогите написать 3 программы. (на С или С++) 1. Вывести на экран в первой строке нечетные символы, во второй четные символы исходной...

3
 Аватар для IrineK
2023 / 1641 / 425
Регистрация: 23.02.2011
Сообщений: 6,002
Записей в блоге: 25
21.11.2013, 03:36
Через массивы можно и так:
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 <stdlib.h>
#include <string.h>
#define size 100
 
int main()
{   int i = 0, j = 0, k = 0;
    char s1[size], s2[size], s3[size];
 
    fgets(s1, size, stdin);
    fgets(s2, size, stdin);
    s1[strlen(s1)-1] = '\0';
    s2[strlen(s2)-1] = '\0';
 
    while(s1[i] != '\0' && s2[j] != '\0')
        if(!(k%2))
            s3[k++] = s1[i++];
        else
            s3[k++] = s2[j++];
    while(s1[i] != '\0')
        s3[k++] = s1[i++];
    while(s2[j] != '\0')
        s3[k++] = s2[j++];
    s3[k] = '\0';
    
    puts(s3);
 
    getchar();
    return 0;
}
Добавлено через 13 минут
И даже еще проще:
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 <stdio.h>
#include <stdlib.h>
#include <string.h>
#define size 100
 
int main()
{   int i = 0, j = 0, k = 0;
    char s1[size], s2[size], s3[size];
 
    fgets(s1, size, stdin);
    fgets(s2, size, stdin);
    s1[strlen(s1)-1] = '\0';
    s2[strlen(s2)-1] = '\0';
 
    while(s1[i] != '\0' && s2[j] != '\0')
    {   s3[k++] = s1[i++];
        s3[k++] = s2[j++];
    }
    while(s1[i] != '\0')
        s3[k++] = s1[i++];
    while(s2[j] != '\0')
        s3[k++] = s2[j++];
    s3[k] = '\0';
    
    puts(s3);
 
    getchar();
    return 0;
}
Добавлено через 40 минут
Та же идея - через библиотечные функции:

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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define size 100
 
int main()
{   int i = 0, j = 0, k = 0;
    char s1[size] = "", s2[size] = "", s3[size+1] = "Z";
 
    fgets(s1, size, stdin);
    fgets(s2, size, stdin);
    s1[strlen(s1)-1] = '\0';
    s2[strlen(s2)-1] = '\0';
 
    while(strlen(s1) > 0 && strlen(s2) > 0)
    {   strncat(s3, s1, 1);
        memmove(s1, s1+1, size);
        strncat(s3, s2, 1);
        memmove(s2, s2+1, size);
    }
    while(strlen(s1) > 0)
    {   strncat(s3, s1, 1);
        memmove(s1, s1+1, size);
    }
    while(strlen(s2) > 0)
    {   strncat(s3, s2, 1);
        memmove(s2, s2+1, size);
    }
    memmove(s3, s3+1, size);
    puts(s3);
 
    getchar();
    return 0;
}
1
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 8
21.11.2013, 21:24  [ТС]
Суть я понял, но все же там они должны формировать третью строку из символов двух других поочередно, т.е.
Вот строка 1
или два
Результат должен выглядеть так:
влт сво а 1

Добавлено через 2 часа 45 минут
И кстати почему он русские символы не воспринимает? ну точнее ввести их можно, но в процессе обработки они превращаются в иероглифы какие-то
0
 Аватар для IrineK
2023 / 1641 / 425
Регистрация: 23.02.2011
Сообщений: 6,002
Записей в блоге: 25
22.11.2013, 01:06
Для меня формирование "из двух других поочередно" мыслится так:
135
2468158
На выходе:1234568158
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.11.2013, 01:06
Помогаю со студенческими работами здесь

Ввести с клавиатуры строку, поменять местами чётные и нечётные символы
Помогите написать программу, которая вводит с клавиатуры строку, меняет местами чётные и нечётные символы и выдаёт на экран. Желательно на...

Проверить, можно ли, меняя местами четные и нечетные символы первой строки, получить вторую строку
На вход поступают две строки. Вывести true если меняя местами четные и нечетные символы одной строки, можно получить вторую строку. Вывести...

Сформировать новую строку, содержащую те же символы, но расположенные в обратном порядке
Разработайте консольное приложение, которое, используя классstd :: stringвводит данные и выводит результат решения данной задачи: Дана...

Строка: Вывести нечетные символы во 2 строку экрана с 5-й позиции, а четные в 23-ю строку с 5-й позиции.
Помогите пожалуйста решить задачу на экзамен. Дана строка символов. Вывести нечетные символы во 2 строку экрана с 5-й позиции, а четные...

Сформировать из данной строки новую строку, удалив все кратные символы
написать программу на си: дана строка АААВВСС, сформировать из нее новую строку АВС,удалив все кратные элементы. заранее спасибо)


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru