Edu144 CD

Dashboard - Educational Codeforces Round 144 (Rated for Div. 2) - Codeforces

C. Maximum Set

思路:要想让集合长度最长,显然令倍数为2,那么可以容易得到最长长度为 l o g 2 ( r / l ) + 1 log2(r/l)+1 log2(r/l)+1。

接下来求个数,首先是所有倍数都为2的集合,上界为 u p = r / ( 1 l l < < c i ) up = r / (1ll << ci) up=r/(1ll<<ci), a n s 1 = ( u p − l + 1 ) ans1=(up - l + 1) ans1=(up−l+1)。

其次可以令一个2变成3,比如第四个样例,4 8 16 32 64--->>>4 12 24 48 96。第二个位置2变3。

我们求出这种情况的上界 u p 1 = r / ( 1 l l < < ( c i − 1 ) ) / 3 up1 = r / (1ll << (ci - 1)) / 3 up1=r/(1ll<<(ci−1))/3, a n s 2 = ( u p 1 − l + 1 ) ∗ c i ) ans2=(up1 - l + 1) * ci) ans2=(up1−l+1)∗ci)。

然后如果两个2变成3或者一个2变成4,都会导致长度变短所以不可行。

所以最终答案 a n s = ( a n s 1 + a n s 2 ) ans=(ans1+ans2)%mod ans=(ans1+ans2)。

cpp 复制代码
void solve()
{
    int l, r;
    cin >> l >> r;
    int len = log2(r / l) + 1;
    int ci = log2(r / l);//2的个数
    int up = r / (1ll << ci); // 第一个上界
    ans = 0;
    ans += (up - l + 1);
    /* cout << up << ' '; */
    int up1 = r / (1ll << (ci - 1)) / 3; // 第二个上界
    if (up1 - l + 1 > 0)
    {
        ans = (ans + (up1 - l + 1) * ci) % mod; //*ci是因为这种情况所有的2都可以变成3
    }
    cout << len << ' ' /*  << up << ' ' << x << ' ' */;
    cout << ans;
}

D. Maximum Subarray

思路:题目要求k个数+x,其他数-x。我们可以先令所有数-x,再选k个数+2*x。

我们考虑 d p [ i ] [ j ] dp[i][j] dp[i][j] 为前i个数选了j个数,容易得到转移方程:

d p [ i ] [ j ] = m a x ( d p [ i − 1 ] [ j ] + a [ i ] , d p [ i − 1 ] [ j − 1 ] + a [ i ] + x ∗ 2 , 0 l l ) dp[i][j]=max(dp[i-1][j]+a[i],dp[i-1][j-1]+a[i]+x*2,0ll) dp[i][j]=max(dp[i−1][j]+a[i],dp[i−1][j−1]+a[i]+x∗2,0ll) 。

cpp 复制代码
void solve()
{
    cin >> n >> k >> x;
    rep(1, i, n)
    {
        cin >> a[i];
        a[i] -= x;
    }
    rep(0, i, n)
    {
        rep(i + 1, j, k)
        {
            dp[i][j] = -1e18;
        }
    }
    ans = 0;
    rep(1, i, n)
    {
        rep(0, j, min(i, k))
        {
            if (j)
            {
                dp[i][j] = max({dp[i - 1][j] + a[i], dp[i - 1][j - 1] + a[i] + 2 * x, 0ll});
            }
            else
            {
                dp[i][j] = max(dp[i - 1][j] + a[i], 0ll);
            }
        }
    }
    rep(1, i, n)
    {
        rep(0, j, min(i, k))
        {
            if (k - j <= n - i) //注意确保没选的k的个数要小于等于当前未选的总数
            {
                ans = max(ans, dp[i][j]);
            }
        }
    }
    cout << ans;
}
相关推荐
CodeByV2 小时前
【C++】C++11:右值引用和移动语义
开发语言·c++
一水鉴天2 小时前
整体设计 全面梳理复盘 之37 元级自动化引擎三体项目(Designer/Master/Transformer)划分确定 + 自用规划工具(增强版)
开发语言·算法·transformer·公共逻辑
头发还没掉光光3 小时前
C/C++类型转换
c语言·开发语言·c++
爪哇部落算法小助手3 小时前
爪哇周赛 Round 1
c语言·c++·算法
TT哇3 小时前
【多源 BFS】3.地图中的最⾼点(medium)
算法·宽度优先
dllxhcjla3 小时前
数据结构与算法 第一天
数据结构·算法
再__努力1点3 小时前
【11】特征检测与匹配:AKAZE特征算法详解与实现
人工智能·python·opencv·算法·计算机视觉·特征提取
Bender_ydc3 小时前
一个基于现代 C++23 Modules 的传统文化算法库,使用纯模块化设计实现(包含大六壬、六爻、紫薇斗数、八字、奇门遁甲)
算法·c++23
Kuo-Teng3 小时前
LeetCode 141. Linked List Cycle
java·算法·leetcode·链表·职场和发展