贪心算法求解活动安排<算法分析>
一、实验内容及要求
1.要求按贪心算法原理求解问题;
2.要求手工输入s[10]及f[10],其中注意自己判断s[i]<f[i];
3.要求显示所有活动及最优活动安排的i事件列表。
二、实验步骤
1、手工输入活动事件;
2、输出活动s数组及f数组;
2、计算最优活动安排后,输出最优i事件列表。
输入:
请输入s数组:
请输入f数组:
输出
s=15,3,2,8.....
f=18,5,4,10.....
i=1,5,8
Java源代码:
package shiyan;
import java.util.Scanner;
public class shiyan3 {
public static void main(String[] args) {
int number=10; //活动数量10个
int[] s = new int[number]; //开始时间数组
int[] f = new int[number]; //结束时间数组
System.out.println("请分别输入"+number+"个活动的开始时间:");
Scanner in_s = new Scanner(System.in);//循环输入开始时间数组
for(int i=0;i<number;i++){
s[i]=in_s.nextInt();}
System.out.println("请分别输入"+number+"个活动的结束时间:");
Scanner in_f = new Scanner(System.in);//循环输入结束时间数组
for(int i=0;i<number;i++){
f[i]=in_f.nextInt();}
System.out.println("开始时间数组s[10]:");
for(int i=0;i<number;i++){ //输出两个数组
System.out.print("["+s[i]+"]"); }
System.out.println("\n结束时间数组f[10]:");
for(int i=0;i<number;i++){
System.out.print("["+f[i]+"]"); }
boolean[] a=new boolean[s.length]; //一个与活动数目等长的 boolean型数组记录每个活动的状态
shiyan3 ac = new shiyan3();
int counts=ac.Activity_arrangement(s, f, a);
System.out.println("\n活动集合中最大相容活动数量为:"+counts);
for(int i=1;i<=s.length-1;i++){
if(a[i]){
System.out.println("第"+i+"活动被选中,其开始时间为:"+s[i-1]+",结束时间为:"+f[i-1]); } } }
public int Activity_arrangement(int[] s,int[] f,boolean[] a){
int n=s.length-1;
a[1]=true; //第一个活动被选中
int j=1;
int count=1; //被选中活动的数量,默认第一个活动被选中
for(int i=2;i<=n;i++){
if(s[i]>=f[j]){ //下一个活动开始时间大于大于等于上一个活动结束时间
a[i]=true;
j=i;
count++; }
else{
a[i]=false;
}
}
return count;
运行结果如下:

贪心算法求解活动安排<算法分析>的更多相关文章
- [C++] 贪心算法之活动安排、背包问题
一.贪心算法的基本思想 在求解过程中,依据某种贪心标准,从问题的初始状态出发,直接去求每一步的最优解,通过若干次的贪心选择,最终得出整个问题的最优解. 从贪心算法的定义可以看出,贪心算法不是从整体上考 ...
- C++贪心算法实现活动安排问题
问题描述: 设有n个活动的集合E={1,2,…,n},其中,每个活动都要求使用同一资源,而在同一时间内只有一个活动能使用这一资源.每个活动i都有一个要求使用该资源的起始时间si和一个结束时间fi,且s ...
- 51nod贪心算法入门-----活动安排问题
有若干个活动,第i个开始时间和结束时间是[Si,fi),只有一个教室,活动之间不能交叠,求最多安排多少个活动? 输入 第1行:1个数N,线段的数量(2 <= N <= 10000) 第2 ...
- 51nod贪心算法入门-----活动安排问题2
题目大意就是给几个活动,问要几个教室能够弄完. 这个题目的想法就是把活动的开始——结束的时间看做是数轴上的一段线段,教室的个数就是在某点的时间厚度,求最大的时间厚度就是所需要的教室个数. #inclu ...
- 基于贪心算法求解TSP问题(JAVA)
概述 前段时间在搞贪心算法,为了举例,故拿TSP来开刀,写了段求解算法代码以便有需之人,注意代码考虑可读性从最容易理解角度写,没有优化,有需要可以自行优化! 详细 代码下载:http://www.de ...
- 雷达覆盖,贪心,类似活动安排(POJ1328)
题目链接:http://poj.org/problem?id=1328 解题报告: 1.按照头结点排序. #include <cstdio> #include <cmath> ...
- 用贪心算法近似求解 Loading Balance 问题(作业调度的负载均衡)
一,Loading Balance 问题描述:有 m 台相同的机器及 n 个作业,其中 m={M(1),M(2),……M(m)}.n = {J(1),J(2),……J(n)}.每个作业都有一个处理时间 ...
- 贪心算法和动态规划[zz]
http://www.cnblogs.com/asuran/archive/2010/01/26/1656399.html 贪心算法 1.贪心选择性质 所谓贪心选择性质是指所求问题的整体最优解可以通过 ...
- 『嗨威说』算法设计与分析 - 贪心算法思想小结(HDU 2088 Box of Bricks)
本文索引目录: 一.贪心算法的基本思想以及个人理解 二.汽车加油问题的贪心选择性质 三.一道贪心算法题点拨升华贪心思想 四.结对编程情况 一.贪心算法的基本思想以及个人理解: 1.1 基本概念: 首先 ...
随机推荐
- Matlab实现图像分割 分类: 图像处理 2014-06-14 21:31 662人阅读 评论(1) 收藏
下面使用极小值点阈值选取方法,编写MATLAB程序实现图像分割的功能. 极小值点阈值选取法即从原图像的直方图的包络线中选取出极小值点, 并以极小值点为阈值将图像转为二值图像 clear all; cl ...
- PWA之serviceWorker应用
1.serviceWorker介绍service worker是一段运行在浏览器后台的JavaScript脚本,在页面中注册并安装成功后,它可以拦截和处理网络请求,实现缓存资源并可在离线时响应用户的请 ...
- 459 Repeated Substring Pattern 重复的子字符串
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000.示例 1:输入: "abab"输出: True解释: 可由 ...
- Android 使用Bitmap将自身保存为文件,BitmapFactory从File中解析图片并防止OOM
1.使用Bitmap将自身保存为文件 public boolean saveBitmapAsFile(String name, Bitmap bitmap) { File saveFile = new ...
- Wamp搭建的服务器登录的时候出现Access denied for user 'hello'@'localhost' (using password: YES)
想用自己电脑做一个服务器,然后就选择了Wamp,本来一切顺利,可是到登录的时候却出现了问题,出现了 Access denied for user 'hello'@'localhost' (using ...
- iOS之NSAttributedString-------字符属性
NSAttributedString 字符属性 字符属性可以应用于 attributed string 的文本中. NSString *const NSFontAttributeName;(字体) N ...
- H.264学习笔记1——相关概念
此处记录学习AVC过程中的一些基本概念,不定时更新. frame:帧,相当于一幅图像,包含一个亮度矩阵和两个色度矩阵. field:场,一帧图像,通过隔行扫描得到奇偶两场,分别称为顶场和底场或奇场和偶 ...
- Farseer.net轻量级ORM开源框架 V1.x 教程目录
本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...
- 关于mapState和mapMutations和mapGetters 和mapActions辅助函数的用法及作用(三)-----mapGetters
简单的理解: const getters = { newCount: function(state){ return state.count += 5; } } ------------------- ...
- python 需求分析
第三章: 需求分析需求分析任务: ??? 功能分析性能分析EG: 相应时间.主存容量.磁盘容量.安全性.等可靠性和可用性出错处理需求系统发现错误时采取的行动,主要在系统关键部分设置接口需求用户接口.硬 ...