Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
Форумчанин.NET
 Аватар для AeroWhite
556 / 427 / 64
Регистрация: 12.02.2013
Сообщений: 834

Найти максимальное покрытие отрезками

10.04.2015, 20:40. Показов 3223. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На прямой взят отрезок, скажем [0...n], также на вход подается k отрезков, разной длины, лежащих на первом отрезке.
Есть ли какой-то алгоритм, позволяющий найти максимально возможное покрытие этими отрезками первого отрезка без пересечения?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.04.2015, 20:40
Ответы с готовыми решениями:

Найти максимальное значение среди элементов массива, которые делят максимальное значение без остатка
Дан целочисленный массив из n элементов. Элементы могут принимать целые значения от 1 до 500. Найдите максимальное значение среди...

Работа с отрезками
Работа с отрезками. Что-то делаю не правильно, нужна помощь. По условию: Файл in.txt cодержит корректные вещественные координаты...

Минимальное покрытие отрезка отрезками. Рекурсия и динамическое программирование
"Дыра" и отрезки на прямой заданы целыми координатами своих концов. "Дыру" нужно закрыть с помощью отрезков; их суммарная...

2
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
10.04.2015, 21:08
Лучший ответ Сообщение было отмечено AeroWhite как решение

Решение

AeroWhite,
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
using System;
using System.Collections.Generic;
using System.Linq;
 
namespace ConsoleApplication180
{
    class Program
    {
        static void Main(string[] args)
        {
            var intervals = new List<Interval> { new Interval(1, 3), new Interval(1, 4), new Interval(4, 6), new Interval(2, 7), new Interval(0, 1) };
            var solver = new Solver();
            var result = solver.Solve(intervals);
 
            Console.WriteLine(string.Join<Interval>(" + ", result));
 
            Console.ReadLine();
        }
    }
 
    class Solver
    {
        public List<Interval> Solve(IEnumerable<Interval> intervals)
        {
            var max = 0f;
            List<Interval> temp = new List<Interval>();
            List<Interval> best = null;
            foreach(var perm in GetPermutations(intervals, temp))
            {
                var sum = perm.Sum(i => i.Length);
                if(sum > max)
                {
                    max = sum;
                    best = perm.ToList();
                }
            }
 
            return best;
        }
 
        IEnumerable<List<Interval>> GetPermutations(IEnumerable<Interval> intervals, List<Interval> result)
        {
            var count = 0;
            foreach(var interval in intervals)
            {
                result.Add(interval);
                foreach (var p in GetPermutations(intervals.Where(i => !i.Intersects(interval)), result))
                    yield return p;
                result.RemoveAt(result.Count - 1);
                count++;
            }
            if (count == 0)
                yield return result;
        }
    }
 
    class Interval
    {
        public readonly float From;
        public readonly float To;
 
        public Interval(float from, float to)
        {
            this.From = from;
            this.To = to;
        }
 
        public float Length
        {
            get { return To - From; }
        }
 
        public bool Intersects(Interval other)
        {
            return !(To < other.From || From > other.To);
        }
 
        public override string ToString()
        {
            return From + ";" + To;
        }
    }
}
2
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
10.04.2015, 21:09
т.е. нужна максимальная сумма k чисел, не превышающая заданное число. Идея такая: складывать числа по убыванию. Если на очередном шаге сумма превышает заданное, берём следующее — меньшее — число.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.04.2015, 21:09
Помогаю со студенческими работами здесь

Найти максимальное число k, для которого существует точка прямой, покрытая k отрезками заданного набора
Дано n отрезков: , i=1,…,n. Найти максимальное число k, для которого существует точка прямой, покрытая k отрезками заданного набора. Число...

Найти расстояние между отрезками
Даны координаты точек двух отрезков, найти расстояние между ними.

Найти угол между отрезками
в прямоугольном параллелепипеде ABCDA1B1C1D1 отношение ребер AB/AD=1/2, а угол между прямыми B1D и CD1 равен 90 градусов. точка M -...

Найти покрытие полным перебором
Всем доброго времени суток. Программирование С++ изучаю недавно. Дали запрограммировать покрытие полным и граничным перебором. Загнал...

Найти расстояние между двумя произвольными заданными на плоскости отрезками
помогите решить....:wall: Отрезки на плоскости. Найти расстояние между двумя произвольными заданными на плоскости отрезками. ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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 Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru