算法学习——贪心算法实践

贪心算法实践:程序存储问题

完成日期:2017.11.21


实验内容

1. 实践题目

程序存储问题

2. 问题描述

设有 n 个程序 { 1 , 2 , 3 , … , n } 要存放在长度为 L 的磁带上。程序i存放在磁带上的长度是 li , 1 ≤ i ≤ n 。要求确定这 n 个程序在磁带上的一个存储方案,使得能够在磁带上存储尽可能多的程序。

3. 算法描述

数据结构:count——当前可存储的程序个数 a[]——存放程序的长度 n——程序的个数 l——磁带的长度
(1)先将数组的元素按非降序排序。
(2)遍历n个程序,判断程序是否可取:
如果磁带的长度l大于程序的长度a[j],则该程序可取,那么可储存的程序个数count值++,同时更新l值,l -= a[j]。
其余情况表示该程序不可取,说明该程序之后的程序均不可取,那么退出循环。
(3)输出count值。

4. 算法时间及空间复杂度分析

时间复杂度:
sort(a,a+n);的时间复杂度为O(nlogn),
for(int i=0;i

5. 程序代码
#include <iostream> 
#include <algorithm> 
using namespace std; 

int Storage(int*a, int n, int l){

    sort(a, a + n); 

    int count = 0;
    for (int j = 0; j < n; j++) { 
        if (l >= a[j]) { 
            count++;     
            l -= a[j]; 
        } else
            break; 
    } 

    return count;
}

int main() { 
    int n, l; 
    cin >> n >> l; 
    int* a = new int[n]; 
    for (int i = 0; i < n; i++) 
        cin >> a[i]; 

    cout << Storage(a, n, l);


} 
6. 程序运行截图

这里写图片描述

7. 心得体会

只要理解贪心算法的思想,再结合起来仔细分析题目,问题就迎难而解了。就程序存储问题而言,既然要求存储最多个程序,那么只要把较小的程序一个个加起来,直到大于总长度就可以了,这就是贪心算法的思想,总是做出对当前最有利的选择。一开始程序一直不能通过是因为后续的for循环中忘了更新l的值,所以造成了错误。由此得知,以后要明白自己所写的每一行代码的作用,写代码时同时在脑海里一定要非常清晰自己的思路、用到哪些变量等等,这样才不会出现这些细节错误。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值