Codeforces Round 909 (Div. 3)

打印 上一主题 下一主题

主题 1884|帖子 1884|积分 5652

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
C. Yarik and Array

题意
求给定命组的连续子序列和的最大值,并且要求子序列中相邻元素奇偶性不同
思路
dp,与求数组最长递增子序列类似
dp表示以元素arr末了的符合条件的子序列的最大和,则递推公式为:dp = max(dp[i - 1] + arr, arr)
  1. void solve()
  2. {
  3.     int n;
  4.     cin >> n;
  5.     vector<int> arr(n + 1);
  6.     fer(i, 1, n + 1) cin >> arr[i];
  7.     int *dp = new int[n + 2];
  8.     dp[0] = 0;
  9.     fer(i, 1, n + 1) dp[i] = arr[i];
  10.     int ans = -1e9;
  11.     fer(i, 1, n + 1)
  12.     {
  13.         if ((arr[i] + arr[i - 1]) & 1)
  14.             dp[i] = max(dp[i - 1] + arr[i], arr[i]);
  15.         ans = max(ans, dp[i]);
  16.     }
  17.     cout << ans << '\n';
  18. }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

宝塔山

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表