2020-12-16

会场安排问题

问题描述:假设要在足够多的会场里安排一批活动,并希望使用尽可能少的会场。设计一个有效的贪心算法进行安排。

输入示例:5                                         输出:3

                    1 23

                    12 28

                     25 35

                     27 80

                     36  50

算法思想:用贪心算法解决这个问题,贪心算法:贪心算法(又称贪婪算法)是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,算法得到的是在某种意义上的局部最优解。也就是说,它总是做出局部最优解,寄希望于通过局部最优解来获得全局最优解。

一个活动的安排,取决于该活动的开始时间和上一个活动的结束时间是否冲突。所以先按照活动的结束时间将所有活动进行排序。然后循环安排活动,循环一遍,尽可能安排最多活动,只要时间不冲突,就在同一个会场,接下来再循环一遍,安排剩下的活动,又是一个会场,直到所有活动都被安排完。

代码:

#include<stdio.h>

struct node{

        int begin;

        int end;

        int flag;//标记活动是否被安排,0表示未安排,1表示以安排

};

int main(){

    int i,j,n;

    struct node temp,t[100];

    scanf("%d",&n);

    //输入活动的开始及结束时间

    for(i=0;i<n;i++){

        scanf("%d%d",&t[i].begin,&t[i].end);

        t[i].flag=0;

     }

//将活动以结束时间进行递增排序(简单选择)

for(i=0;i<n;i++){

    for(j=i+1;j<n;j++){

        if(t[i].end>t[j].end){

            temp.end=t[i].end;

            t[i].end=t[j].end;

            t[j].end=temp.end;

            }

        }

}

    int sum;//总共需要的会场数目

    int count;//当前以安排的活动数目

    while(count<n){

            int end_time=0;

            for(i=0;i<n;i++){

                    if(t[i].begin>end_time&&t[i].flag==0){

                        count++;

                        t[i].flag=1;

                        end_time=t[i].end;

            }

        }

    sum++;

    }

    printf("%d",sum);

}

运行截图:

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 删数问题 问题描述:给定n位正整数a,去掉其中任意k<=n个数字后,剩下的数字按原次序排列组成一个新的正整数,对于...
    小王是一条咸鱼阅读 1,022评论 0 0
  • 简介 atop是一款用于监控Linux系统资源与进程的工具,它以一定的频率记录系统的运行状态,所采集的数据包含系统...
    爱钓鱼的码农阅读 4,962评论 0 0
  • 51. 加法 不使用+、-,计算两数字之和 52. 至少有K个重复字符的最长子串 找到给定字符串(由小写字符组成)...
    毒死预言家的女巫阅读 3,957评论 0 0
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 12,214评论 16 22
  • 今天感恩节哎,感谢一直在我身边的亲朋好友。感恩相遇!感恩不离不弃。 中午开了第一次的党会,身份的转变要...
    余生动听阅读 13,597评论 0 11

友情链接更多精彩内容