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

Разбить каждую строку на отдельные слова. В каждой строке оставить только самое длинное слово

23.12.2021, 21:47. Показов 1150. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать программу, производящую операции над текстовыми входными данными согласно своему варианту. Указанные в варианте операции производятся циклично над каждой отдельной строкой. Если программе не переданы аргументы командной строки, входные данные запрашиваются с клавиатуры. В противном случае первый аргумент командной строки используется как имя файла, из которого входные данные прочитываются построчно.

При обработке ручного ввода:

Пользователь сначала вводит количество строк, а затем сами строки;
Допустимо использовать тип данных string;
Результат работы программы должен выводиться на экран.
При обработке данных из файла:

Необходимо применить StringBuilder;
Результат работы программы должен выводиться в другой файл, путь до которого указывается во втором аргументе командной строки.


Вариант 10
Разбить каждую строку на отдельные слова. В каждой строке оставить только самое длинное слово.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.12.2021, 21:47
Ответы с готовыми решениями:

Оставить в каждой строке файла только самое длинное слово
Помогите , пожалуйста, исправить программу, работает не совсем правильно.почему-то оставляет первые слова каждой строки. Вот задачка: ...

Преобразовать файл, оставив в каждой строке только самое длинное слово
Помогите написать программу: Дан файл. Преобразовать его, оставив в каждой строке только самое длинное слово

Преобразовать текстовый файл, оставив в каждой строке только самое длинное слово
Дан текстовый файл. Преобразовать его, оставив в каждой строке только самое длинное слово. Доходит до строки 23 и перекидывает аж на...

2
0 / 0 / 0
Регистрация: 18.09.2021
Сообщений: 8
22.05.2022, 02:08  [ТС]
Написать программу, производящую операции над текстовыми входными данными согласно своему варианту. Указанные в варианте операции производятся циклично над каждой отдельной строкой. Если программе не переданы аргументы командной строки, входные данные запрашиваются с клавиатуры. В противном случае первый аргумент командной строки используется как имя файла, из которого входные данные прочитываются построчно.

При обработке ручного ввода:

Пользователь сначала вводит количество строк, а затем сами строки;
Допустимо использовать тип данных string;
Результат работы программы должен выводиться на экран.
При обработке данных из файла:

Необходимо применить StringBuilder;
Результат работы программы должен выводиться в другой файл, путь до которого указывается во втором аргументе командной строки.


Вариант 10
Разбить каждую строку на отдельные слова. В каждой строке оставить только самое длинное слово.
0
0 / 0 / 0
Регистрация: 22.05.2022
Сообщений: 1
22.05.2022, 23:43
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
86
87
88
89
90
91
92
93
94
95
96
97
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Console = System.Console;
 
namespace ConsoleAppDelete
{
    class Program
    {
        public static void Main(string[] args)
        {
            List<List<string>> words;
            string[] longestWords;
 
            if (args.Length >= 1)
            {
                InputTextFromFile(out words, args[0]);
                ShowLongestWords(words, out longestWords);
                if (args.Length >= 2)
                {
                    OutputWordsToFile(longestWords, args[1]);
                }
            }
            else
            {
                ManualInput(out words);
                ShowLongestWords(words, out longestWords);
            }
            
            Console.ReadKey();
        }
 
        private static void OutputWordsToFile(string[] longestWords, string fileName)
        {
            var wordStringBuilder = new StringBuilder();
 
            foreach (var word in longestWords)
            {
                wordStringBuilder.Append(word);
            }
 
            File.WriteAllText(fileName, string.Join(", ", wordStringBuilder));
        }
 
        private static void InputTextFromFile(out List<List<string>> words, string fileName)
        {
            words = System.IO.File.ReadAllLines(fileName)
                .Select(line => new List<string>(line.Split(' ')))
                .ToList();
 
            Console.WriteLine($"Текст из файла {fileName} прочитан.");
        }
 
        public static void ManualInput(out List<List<string>> words)
        {
            int linesCount;
            words = new List<List<string>>();
            
            Console.Write("Введите количество строк: ");
            while (!int.TryParse(Console.ReadLine(), out linesCount))
            {
                Console.Write("Не число. Повторите ввод: ");
            }
 
            for (int i = 0; i < linesCount; i++)
            {
                Console.Write($"\nВведите строку {i + 1}:");
                words.Add(new List<string>(Console.ReadLine().Split(' ')));
            }
        }
 
        public static void ShowLongestWords(List<List<string>> words, out string[] longestWords)
        {
            int linesCount = words.Count;
 
            longestWords = new string[linesCount];
            for (int i = 0; i < linesCount; i++)
            {
                int maxLength = 0;
 
                foreach (var word in words[i])
                {
                    if (word.Length > maxLength)
                    {
                        maxLength = word.Length;
                        longestWords[i] = word;
                    }
                }
            }
 
            Console.WriteLine($"Самые длинные слова: {string.Join(", ", longestWords)}");
        }
    }
}
Добавлено через 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
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
86
87
88
89
90
91
92
93
94
95
96
97
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Console = System.Console;
 
namespace ConsoleAppDelete
{
    class Program
    {
        public static void Main(string[] args)
        {
            List<List<string>> words;
            string[] longestWords;
 
            if (args.Length >= 1)
            {
                InputTextFromFile(out words, args[0]);
                ShowLongestWords(words, out longestWords);
                if (args.Length >= 2)
                {
                    OutputWordsToFile(longestWords, args[1]);
                }
            }
            else
            {
                ManualInput(out words);
                ShowLongestWords(words, out longestWords);
            }
            
            Console.ReadKey();
        }
 
        private static void OutputWordsToFile(string[] longestWords, string fileName)
        {
            var wordStringBuilder = new StringBuilder();
 
            foreach (var word in longestWords)
            {
                wordStringBuilder.Append(word + ", ");
            }
 
            File.WriteAllText(fileName, wordStringBuilder.ToString().Substring(0, wordStringBuilder.Length - 2));
        }
 
        private static void InputTextFromFile(out List<List<string>> words, string fileName)
        {
            words = System.IO.File.ReadAllLines(fileName)
                .Select(line => new List<string>(line.Split(' ')))
                .ToList();
 
            Console.WriteLine($"Текст из файла {fileName} прочитан.");
        }
 
        public static void ManualInput(out List<List<string>> words)
        {
            int linesCount;
            words = new List<List<string>>();
            
            Console.Write("Введите количество строк: ");
            while (!int.TryParse(Console.ReadLine(), out linesCount))
            {
                Console.Write("Не число. Повторите ввод: ");
            }
 
            for (int i = 0; i < linesCount; i++)
            {
                Console.Write($"\nВведите строку {i + 1}:");
                words.Add(new List<string>(Console.ReadLine().Split(' ')));
            }
        }
 
        public static void ShowLongestWords(List<List<string>> words, out string[] longestWords)
        {
            int linesCount = words.Count;
 
            longestWords = new string[linesCount];
            for (int i = 0; i < linesCount; i++)
            {
                int maxLength = 0;
 
                foreach (var word in words[i])
                {
                    if (word.Length > maxLength)
                    {
                        maxLength = word.Length;
                        longestWords[i] = word;
                    }
                }
            }
 
            Console.WriteLine($"Самые длинные слова: {string.Join(", ", longestWords)}");
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.05.2022, 23:43
Помогаю со студенческими работами здесь

Дан файл. Преобразовать его, оставив в каждой строке только самое длинное слово. Использовать собственный написанный мод
Дан файл. Преобразовать его, оставив в каждой строке только самое длинное слово. Использовать собственный написанный мод

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

Самое длинное слово строки разбить на два слова пополам
Самое длинное слово (первое из самых длинных, если их несколько) разбить на два слова пополам. Если в этом слове нечетное количество...

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

Найти самое длинное и самое короткое слово в заданном массиве и записать только эти слова в текстовый файл
Доброго времени суток! Помогите пожалуйста решить задачу:Из текстового файла, состоящего из 6-7 строк сформировать массив слов. Найти самое...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru