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

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

26.11.2017, 17:33. Показов 3767. Ответов 3

Author24 — интернет-сервис помощи студентам
Мне нужно создать программу, которая получает на вход строку, состоящую из слов(подстрок), их разбивает, а потом выводит
в виде цепочки слов(чтобы последний символ первого слова совпадал с первым символом второго слова и т.д.) Я нашёл похожее
задание, только в нём цепочка создаётся из написанных слов в строке ws:
C# Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
    static string aggregate(string[] words, int maxLength = 64, string accumulator = "")
    {
      if (words == null || words.Length == 0) throw new ArgumentException();
      if (maxLength == 0) return accumulator;
      if (string.IsNullOrEmpty(accumulator)) accumulator = words.First();
      else
      {
        string next = words.FirstOrDefault(w => w.First() == accumulator.Last());
        if (next == null) return accumulator;
        else accumulator += " " + next;
      }
      return aggregate(words, maxLength - 1, accumulator);
    }
    
    public static void Main()
    {
        string[] ws = new[] { "lolo", "float", "weather", "rote", "toas", "sola", "atw", "olaf",  };
        Console.WriteLine(aggregate(ws));
    }
Собственно, я попытался заменить в public static void Main() алгоритм, но в итоге ничего не работает, потому что из массива a, состоящего из слов, программа не может получить цепочку и выдаёт ошибку:
public static string [] a;
C# Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
    public static void Main()
    {
        string s;
        s = Convert.ToString(Console.ReadLine());
        string[] everyword;
        Console.WriteLine("Слова из строки:");
        everyword = s.Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
        foreach (string a in everyword)
        {
            Console.WriteLine(a);
        }
        Console.WriteLine("Цепочка слов:"+aggregate());
        Console.Read();
Может есть какой-нибудь способ получить вот строку string[] ws = new[] { "lolo", "float", "weather", "rote", "toas", "sola", "atw", "olaf", };, только состоящую из введённых мною слов?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.11.2017, 17:33
Ответы с готовыми решениями:

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

Напечатать слова предложения в таком порядке, чтобы последняя буква каждого слова совпадала с первой буквой следующего слова
Помогите пожалуйста, заранее спасибо. Добавлено через 22 часа 21 минуту ап, выручите пожалуйста( Добавлено через 18 часов 13...

Если первая буква второго слова совпадает с последней буквой третьего слова, поменять местами второе и третье
Дан текст, слова которого отделяются друг от друга пробелами. Если первая буква второго слова совпадает с последней буквой третьего слова,...

3
 Аватар для worldown
189 / 177 / 111
Регистрация: 22.06.2009
Сообщений: 533
27.11.2017, 00:51
Лучший ответ Сообщение было отмечено alex1131 как решение

Решение

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
using System;
using System.Linq;
 
namespace Rextester
{
    public class Program
    {
        public static void Main(string[] args){
           Console.WriteLine("Введите слова через пробел");
           string[] a = Console.ReadLine().Split();
           for(int i = 0; i < a.Length - 1; i++) {
               for(int j = i+1; j < a.Length; j++){
                    if(a[i].Last() == a[j].First()){
                       string tmp = a[j];
                       a[j] = a[i+1];
                       a[i+1] = tmp;
                   }
               }
           }
           Console.WriteLine();
           foreach(string i in a)
              Console.Write(i + " ");
       }
    }
}
1
0 / 0 / 2
Регистрация: 26.11.2017
Сообщений: 10
29.11.2017, 19:51  [ТС]
Спасибо большое! Я не додумался использовать сортировку. Спасибо за идею!
Мне пришлось немного доработать код, потому что программа работала не совсем корректно.
Вот доработанный код:

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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Введите слова через пробел");
            string[] a = Console.ReadLine().Split();
            Console.WriteLine("Слова из строки:");
            for (int k = 0; k < a.Length; k++)
            {
                Console.WriteLine(a[k]);
            }
            for (int i = 0; i < a.Length - 1; i++)
            {
                for (int j = i + 1; j < a.Length; j++)
                {
                    if (a[i].Last() == a[j].First())
                    {
                        string temp = a[j];
                        a[j] = a[i + 1];
                        a[i + 1] = temp;
                    }
                    if (a[i].First() == a[j].Last())
                    {
                        string temp = a[i];
                        a[i] = a[j];
                        a[j] = temp;
                    }
                }
            }
           Console.WriteLine("Цепочка слов:");
           foreach(string i in a)
              Console.Write(i + " ");
           Console.Read();
       }
    }
        }
0
Почетный модератор
Эксперт по компьютерным сетямЭксперт Windows
 Аватар для magirus
28047 / 15783 / 983
Регистрация: 15.09.2009
Сообщений: 67,753
Записей в блоге: 78
29.11.2017, 21:52
alex1131, правильно использовать теги так: [CSHARP]тут ваш код[/CSHARP]
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.11.2017, 21:52
Помогаю со студенческими работами здесь

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

Расположить слова так, чтобы буква, на которую заканчивается слово, была такой же, как первая буква следующего слова
Даны простые слова. Нужно составить такой порядок, чтобы буква на которую заканчивается слово была такой же как первая буква следующего...

Если последняя буква первого слова и первая буква слова максимальной длины одинаковы, то поменять их местами
Дана строка, слова разделены одним пробелом, в конце точка. Если последняя буква первого слова и первая буква слова максимальной длины...

Если последняя буква последнего слова и первая буква слова минимальной длины одинаковы, то поменять их местами
написать программу на зыке Pascal для обработки строк. Строка должна вводиться с клавиатуры. Полученная строка и другие элементы должны...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели. Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
На любовном киберфронте
Alexander-7 01.04.2025
Недавно на одном малоизвестном сайте знакомств мною заинтересовалась девушка: «Текст немного странный. Но, судя по адресу почты, иностранка», – подумал я. Поколебавшись пару суток, я ответил ей:. . .
Как работает Node.js изнутри
run.dev 29.03.2025
Node. js изменил подход к разработке веб-приложений, позволив использовать JavaScript не только на стороне клиента, но и на сервере. Созданный в 2009 году Райаном Далем, этот открытый,. . .
Моки в Python: Mock Object Library
py-thonny 29.03.2025
Тестирование кода требует особого подхода, когда речь идёт о компонентах, взаимодействующих с внешним миром. Мы часто сталкиваемся с непредсказуемостью HTTP-запросов, чтением данных из базы или. . .
JavaScript: Управление памятью и улучшение производительности
run.dev 29.03.2025
В отличие от низкоуровневых языков программирования, JavaScript не требует ручного выделения и освобождения памяти. Здесь работает автоматический сборщик мусора, который определяет, какие объекты. . .
Мультитенантная архитектура со SpringBoot и PostgreSQL
ArchitectMsa 29.03.2025
SaaS-приложения редко обслуживают одного клиента и обычно они должны поддерживать множество организаций, каждая из которых работает в своём изолированном пространстве. Мультитенантная архитектура. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер