[算法设计]贪心法实例——任务安排问题(Java实现)

复制代码
package selecter;

import java.util.Arrays;

public class ActivitySelecter {
    
    public static final int N = 10;
    static int[] S = new int[] {1, 3, 0, 5, 3, 5, 6, 8, 8, 2, 12};
    static int[] F = new int[] {4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14};

    public static void Selecter(int st,int fi,int []a) {
        
        int p = 1;
        int i = st;
        a[0] = i;
        
        for(int j=i+1;j<=fi;j++) {
            if(S[j]>=F[i]) {
                a[p]=j;
                p++;
                i=j;
            }
        }
    }

    public static void main(String[] arges) {
        //测试函数
        int []a = new int [N];
        Selecter(0,N,a);
        System.out.println(Arrays.toString(a));
    }
}
复制代码

 

posted @   Masahiko  阅读(359)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
点击右上角即可分享
微信分享提示