双机调度算法

假设当前有两个处理机A、B,以及n个待处理的任务。第i个任务在处理处理机A上处理需要的时间为ai,在处理机B上处理的时间为bi,两个处理机可以并行处理任务,但单个处理机不能同时执行任务。要求给定n个任务及各个任务对应的ai 、bi,求得顺序完成这些任务所需要的最短时间

ans:

动态规划算法,最重要的是找出状态转移方程。直接上答案,后续再补充做解释:

c 复制代码
#include<stdio.h>

#define min(a,b) ((a<=b)?a:b)
#define max(a,b) ((a<=b)?b:a)

#define n 5         //作业
int a[n]={2,6,7,9,12};
int b[n]={2,6,7,9,12};
int dp[20][1000]; // dp[i][j]表示前i个作业中A机器花费j的时候,B所花的时间

int main(void) {
    int sum = 0;
    for(int i=1; i<=n; i++) {
        sum+=a[i];
        for(int j=0; j<=sum; j++) {
            dp[i][j]=dp[i-1][j]+b[i];
            if(j>=a[i]) {
                dp[i][j]=min(dp[i-1][j]+b[i], dp[i-1][j-a[i]]);
            }
        }
    }
    int ans = 99999;
    for(int i = 0; i <= sum; i++) {
        ans = min(ans, max(dp[n][i],i));
    }
    printf("ans = %d\n", ans);
}
相关推荐
会编程的土豆几秒前
【数据结构与算法】 树
数据结构·算法
三佛科技-134163842125 分钟前
FT8440E 与FT8440S-RT非隔离12V/18V 200MA开关电源芯片区别与联系?
单片机·嵌入式硬件·物联网·智能家居·pcb工艺
LSL666_9 分钟前
Redis值数据类型——hash
redis·算法·哈希算法·数据类型
喵喵蒻葉睦10 分钟前
力扣 hot100 滑动窗口最大值 单调双端队列 java 简单题解
java·数据结构·算法·leetcode·双端队列·滑动窗口·队列
样例过了就是过了12 分钟前
LeetCode热题100 搜索二维矩阵
数据结构·c++·算法·leetcode·矩阵
2401_8319207417 分钟前
C++与Qt图形开发
开发语言·c++·算法
同年紀20 分钟前
C8051 U-EC6 keil无法连接下载器解决办法
单片机·嵌入式硬件
Shining059620 分钟前
AI 编译器系列(四)《AI 编译器中的后端优化》
linux·服务器·人工智能·线性代数·算法·triton·ai编译器
LCG元36 分钟前
STM32项目开发:基于HC-SR04的超声波测距与倒车雷达系统
stm32·单片机·嵌入式硬件
像污秽一样38 分钟前
算法设计与分析-习题8.1
数据结构·算法·dfs·dp