• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

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

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Прямоугольник и квадраты. Программирование на Си. Параллелизм

  • Автор темы Автор темы Qween
  • Дата начала Дата начала

Qween

Ученик
Регистрация
17 Ноя 2013
Сообщения
1
Реакции
0
Баллы
0
Прямоугольник и квадраты. Программирование на Си. Параллелизм

Здравствуйте форумчане, есть такая задача: "Имеются m квадратов с длинами сторон a1,a2,... и прямоугольник с высотой и шириной, равными h и w соответственно. Найти некоторое подмножество квадратов, которые нужно разместить внутри прямоугольника таким образом, что бы они не пересекались и закрывали максимальную часть площади прямоугольника. Вычисление должны проводится на нескольких компах (физическая связь), должен присутствовать параллелизм"

Я мало программирую, дошел тока до этого.

#include<stdio.h>
#include<conio.h>
#include<alloc.h>
#include<math.h>
#include<time.h>

int main()
{
metka:
clrscr();
int* ptd, n, m, i, dlina, visota,Spr, comb;
char ch;
clock_t t1=clock();
printf("\n Vvedite chislo kvadratov: ");
scanf("%d", &n);
ptd=(int *)malloc(n*sizeof(int));
if(ptd != NULL)
{
for (i=0; i<n; i++)
{
printf("\n Dla %d-ogo kvadrata vvedite storonu: ", i+1);
scanf("%d", &m);
ptd=m;
}
}
else printf("Ne ydalos videlit' pamat'!");
printf("\n Storony kvadratov:");
for (i=0; i<n; i++)
printf(" %d", ptd);
comb=pow(2,n);
printf("\n \n Kolichestvo kombinacii = %d", comb);
printf("\n \n Vvedite dlinu pramougolnika: ");
scanf("%d", &dlina);
printf("\n Vvedite visotu pramougolnika: ");
scanf("%d", &visota);
Spr=dlina*visota;
printf("\n S pramougolnika = %d \n", Spr);
free(ptd);
clock_t t2=clock();
printf("\n Vrema vipolnenia %d", t2-t1);
printf("\n \n Zanogo zaglavnaia 'Y', vihod lubuio druguio: ");
if(ch=getch()=='Y')
goto metka;
return 0;
}

Если кто-то может помочь алгоритмом или кодом буду благодарен.
 
Назад
Сверху