1 月 30 日算法练习-贪心和思维

巧克力

思路:贪心先选价格小的巧克力,如果价格一样选保质期大的。维护天数数组,选了巧克力后从保质期最后一天往前食用。

cpp 复制代码
#include<iostream>
#include<set>
#include<stdbool.h>
using namespace std;

const int N = 1e5+10;
set<int>se;
int x,n;

struct node{
    int val,L,cnt;
    bool operator < (const struct node &b)const{
        if(val == b.val) return L > b.L;
        return val < b.val;
    }
}a[N];

int main( ){
    cin>>x>>n;
    for(int i=1;i<=n;i++)cin>>a[i].val>>a[i].L>>a[i].cnt;
    sort(a+1,a+1+n);
    
    for(int i=1;i<=x;i++)se.insert(i);
    
    int p = 1,res=0;
    while (se.size()&&p<=n) {
        
        while(se.size()&&a[p].cnt&&*se.begin()<a[p].L ){
            res+=a[p].val;
            a[p].cnt--;
            
            auto it = se.upper_bound(a[p].L);
            it--;
            se.erase(it);
            
        }
        
        p++;
    }
    if(se.size())cout<<-1<<'\n';
    cout<<res<<'\n';
    return 0;
}

答疑

思路:贪心每次选 s+a+e 最小的,能保证总体开始答疑时间和最小

cpp 复制代码
#include<iostream>
#include<stdbool.h>
using namespace std;
using ll = long long;
const int N = 1e3+10;

struct node{
    int s,a,e;
    
    bool operator <(const struct node &x) const{
        return s+a+e < x.s + x.a + x.e;
    }
    
}a[N];

int main( ){
    int n;cin>>n;
    for(int i=1;i<=n;i++)cin>>a[i].s>>a[i].a>>a[i].e;
    sort(a+1,a+1+n);
    ll res = 0;
    for(int i=1;i<=n;i++){
        res+= (n + 1 - i)*(a[i].a+a[i].s) + ( n-i )*(a[i].e);
    }
    cout<<res<<'\n';
    return 0;
}

皮亚诺曲线



思路:思维题,找规律。

  1. 求距离可以分解为块内距离和块外距离。块外距离=(块号-1)*3^(阶数-1)* 3^(阶数-1)
  2. 块内距离通过(坐标/3^(阶数-1))来得到。
  3. 通过递归逐渐到阶数为 1,返回块号-1,块号从 1 开始。
  4. 把块 1 作为标准块,递归过程中
  5. 在不同的阶数中,块号排列顺序是不同的,所以每个阶数需要重新获得,(x,y)的块号
cpp 复制代码
#include<iostream>
#include<algorithm>
#include<map>
using namespace std;
using ll = long long;
map<pair<int,int>,int>mp;
ll p[40];
ll cala(ll k,ll x,ll y,map<pair<int,int>,int> mp){
    ll x_ = x/p[k-1],y_ = y/p[k-1];
    if(k==1)return mp[make_pair(x_, y_)]-1;
    map<pair<int,int>,int> mp1;
    ll ans = (mp[make_pair(x_, y_)]-1)*p[k-1]*p[k-1];
    if((x_==0&&y_==1)||(x_==2&&y_==1))
        for(int i=0;i<=2;i++)for(int j=0;j<=2;j++)mp1[make_pair(2-i,j)]=mp[make_pair(i,j)];
    else if((x_==1&&y_==0)||(x_==1&&y_==2))
        for(int i=0;i<=2;i++)for(int j=0;j<=2;j++)mp1[make_pair(i,2-j)]=mp[make_pair(i,j)];
    else if(x_==1&&y_==1)
        for(int i=0;i<=2;i++)for(int j=0;j<=2;j++)mp1[make_pair(2-i,2-j)]=mp[make_pair(i,j)];
    else mp1 = mp;
    return ans += cala(k-1,x_%p[k-1],y_%p[k-1],mp1);
}

int main( ){
    ll k,x1,x2,y1,y2;cin>>k>>x1>>y1>>x2>>y2;
    p[0]=1;
    for(int i=1;i<=39;i++)p[i] = p[i-1]*3;
    mp[make_pair(0,0)]=1;mp[make_pair(0,1)]=2;mp[make_pair(0,2)]=3;
    mp[make_pair(1, 2)]=4;mp[make_pair(1, 1)]=5;mp[make_pair(1, 0)]=6;
    mp[make_pair(2, 0)]=7;mp[make_pair(2, 1)]=8;mp[make_pair(2, 2)]=9;
    ll a =cala(k,x1,y1,mp);
    ll b =cala(k,x2,y2,mp);
    cout<<abs(a-b)<<'\n';
    return 0;
}
相关推荐
一直学习永不止步3 分钟前
LeetCode题练习与总结:赎金信--383
java·数据结构·算法·leetcode·字符串·哈希表·计数
小刘|34 分钟前
《Java 实现希尔排序:原理剖析与代码详解》
java·算法·排序算法
jjyangyou39 分钟前
物联网核心安全系列——物联网安全需求
物联网·算法·安全·嵌入式·产品经理·硬件·产品设计
van叶~1 小时前
算法妙妙屋-------1.递归的深邃回响:二叉树的奇妙剪枝
c++·算法
简简单单做算法1 小时前
基于Retinex算法的图像去雾matlab仿真
算法·matlab·图像去雾·retinex
云卓SKYDROID1 小时前
除草机器人算法以及技术详解!
算法·机器人·科普·高科技·云卓科技·算法技术
半盏茶香2 小时前
【C语言】分支和循环详解(下)猜数字游戏
c语言·开发语言·c++·算法·游戏
徐子童2 小时前
双指针算法习题解答
算法
想要打 Acm 的小周同学呀2 小时前
LRU缓存算法
java·算法·缓存
劲夫学编程3 小时前
leetcode:杨辉三角
算法·leetcode·职场和发展