贪心算法作业参考:P1106,P4995,P5019

贪心算法作业参考:P1106,P4995,P5019

P1106 删数问题

作业批注: 原作业提交,是删除k个最大的数。 不一定是删除最大的数。

参考如下,用例:

输入:

复制代码
50074897
2

输出:

c++ 复制代码
4897
C++ 复制代码
//string erase函数,erase(i,n),从i开始连续删除n个
//每一次找高峰,删掉最坏数,高峰的数一定比后面的数差,因此删掉
#include <bits/stdc++.h>

using namespace std;

const int N = 255;

string num_str;

int main()
{
    int k;
    cin>>num_str>>k;
    while(k--)
    {
        int x=0;
        // 如果当前的数比后一个小,则x指针一直下移
        while(num_str[x]<=num_str[x+1]&&x<num_str.size()) x++;
        // 发现后一个比前一个大下标x,则删除当前数。 即每次删除高峰数。 贪心算法。
        num_str.erase(x,1);
    }
    // 如果,处理结果首位是0, 则把零去除
    while(num_str[0]=='0'&&num_str.size()>1) num_str.erase(0,1);
    cout<<num_str;
    return 0;
}
 
 

P4995 跳跳!

c++ 复制代码
#include <bits/stdc++.h>
using namespace std;

typedef unsigned long long ull;
const int N = 310;

int n;
int a[N];

int main(){
  cin >> n;

  for (int i = 1; i <= n; i++){
  cin >> a[i];
  }

  //从小到大进行排序
  sort(a+1, a+1+n);
   //第1次跳的是最高位置
  ull ans = a[n] * a[n];  

  int i = 1, j = n;
  while (i < j){
     //跳到最低位置
    ans += (a[j] - a[i]) * (a[j] - a[i]);  
     //跳到没调的地方中最高的
    j --;  
    //最低的位置跳到最高位置
    ans += (a[i] - a[j]) * (a[i] - a[j]);  
    i ++;
  }
  cout << ans;
  return 0;
}

P5019 [NOIP 2018 提高组] 铺设道路

用例:

复制代码
5
6 6 8 9 7

9

以上结果解释: 修筑路段,以及当天后剩余待处理的深度

1,5\] 5 5 7 8 6 \[1,5\] 4 4 6 7 5 \[1,5\] 3 3 5 6 4 \[1,5\] 2 2 4 5 3 \[1,5\] 1 1 3 4 2 \[1,5\] 0 0 2 3 1 \[3,5\] 0 0 1 2 0 \[3,4\] 0 0 0 1 0 \[4,4\] 0 0 0 0 0 ```c++ // 贪心规律,第一段为至少的天数,以后每高一个深度算一天,及时断开的,后面深度差需要单独按天处理 #include using namespace std; int a[100005]; long long ans,n; int main() { cin >> n; // 从1下标开始到n for(int i=1;i<=n;i++) cin >> a[i]; // 初始化,ans为第一段的深度处理天数。即至少处理第一段深度的天数 ans = a[1]; for(int i=2;i<=n;i++) if(a[i]>a[i-1]) ans+=a[i]-a[i-1]; cout << ans; return 0; } ```

相关推荐
笑口常开xpr几秒前
【C++继承】深入浅出C++继承机制
开发语言·数据结构·c++·算法
让我们一起加油好吗1 小时前
【基础算法】DFS
算法·深度优先
爱学习的小鱼gogo2 小时前
python 矩阵中寻找就接近的目标值 (矩阵-中等)含源码(八)
开发语言·经验分享·python·算法·职场和发展·矩阵
红纸2812 小时前
Subword算法之WordPiece、Unigram与SentencePiece
人工智能·python·深度学习·神经网络·算法·机器学习·自然语言处理
CUMT_DJ3 小时前
从零复现论文(1)——通感一体化实现协作基站分配与资源分配(CBARA)策略
算法·通感一体化
tt5555555555553 小时前
CSDN 教程:C++ 经典字符串与栈算法题逐行详解
c++·算法·哈希算法
_dindong4 小时前
基础算法:滑动窗口
数据结构·学习·算法·leetcode·力扣
Voyager_44 小时前
图像处理踩坑:浮点数误差导致的缩放尺寸异常与解决办法
数据结构·图像处理·人工智能·python·算法
文艺倾年4 小时前
【八股消消乐】手撕分布式协议和算法(基础篇)
分布式·算法
万岳科技系统开发5 小时前
从源码优化外卖配送系统:算法调度、智能推荐与数据分析应用
算法·数据挖掘·数据分析