Educational Codeforces Round 161 (Rated for Div. 2) E. Increasing Subsequences 动态规划逼近,二进制拆分补充,注意严格递增

这篇具有很好参考价值的文章主要介绍了Educational Codeforces Round 161 (Rated for Div. 2) E. Increasing Subsequences 动态规划逼近,二进制拆分补充,注意严格递增。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Problem - E - Codeforces

目录

推荐视频:

题意:

细节(我踩得没什么价值的坑):

思路:

对样例3 (X = 13)做解释:

——————

总思路:

——————

动态规划逼近:

——————

二进制拆分补充剩余:

核心代码: 


推荐视频:

E_哔哩哔哩_bilibili

其实有一些细节说的不是特别清楚好理解,可以结合我的题解来看。但是对题目的解析说的还是特别好的 

题意:

你需要制作一个数组,使其严格递增子序列的数目为X

细节(我踩得没什么价值的坑):

1.严格递增strictly increasing,我直到看了别人的题解才发现,,才能看懂样例,,

2.好好读题,我靠X是1e18了,得long long

3.快速逼近的时候while循环记得写<=

4.空也算一个序列(这个坑我没踩)

思路:

对样例3 (X = 13)做解释:

组合数解释:

2 2 3 4 2
单独一个数一组:
5   2,2,3,4,2
两个数一组:
5   23 23 24 24 34
三个数一组:
2   234,234

总共12,然后加上题目说的空也算一组,一共13组啦

——————

总思路:

此题我们用动态规划快速逼近答案,然后二进制拆分补充剩余的

(本题解没有去探讨题目中的长度最长为200

不过单调递增就是最快的了)

——————

动态规划逼近:

然而他给这个数组不太适合弄规律(当然方法不止一种哦) 

我们动态规划的思想来规则地做这道题:

我们用arr[ i ]记录 i 及此前的所有严格递增子序列总数目

比如 1 2 3 4

arr[ 1 ] = 1     (1自己,只有1个)

arr[ 2 ] = 3       为 arr[ 1 ]*2 +1  ,

解释:这里arr[ 1 ]*2理解为两个arr[ 1 ],

第一个arr[1]是不算2的此前所有的严格递增子序列总数目

第二个arr[1]代表此前的子序列尾都加个2的序列,这样形成的序列的数目是等于arr[ i-1 ]的;

第三个1就是我们2单独自己啦。

(所以状态转移方程就是 arr[ i ] = arr[ i-1 ]*2 +1 )

此后同理,所以

arr[ 3 ] = 7        (arr[2]*2+1) 

arr[ 4 ] = 15    (7*2+1)

——————

二进制拆分补充剩余:

(剩余的数是个数,肯定能用二进制来表示)

先看例子直接理解:

1 2 3 4 2

顺序后面补个2,我们可以发现2只会和前面的2之前的数形成严格递增序列,此时能形成两个:

2 和 1 2

其中:

1 2其实就是我们上面动态规划部分提到的 “ 第二个1代表此前的子序列尾都加个2的序列 

2就是单独自己啦

所以补的这个值即是arr[ i ] + 1啦

————

(再举个例子,比如1 2 3 4 3,补的是3,补的序列是: 3和 1 3,1 2 3,2 3 共4种)

又因为:

1                         (补1)

arr[ 1 ] + 1 = 2    (补2)    

arr[ 2 ] + 1 = 4    (补3)

arr[ 3 ] + 1 = 8

arr[ 4 ] + 1 = 16

正好是二进制  (注意我们倒着补,后面不再组成递增序列)

——————————文章来源地址https://www.toymoban.com/news/detail-836745.html

核心代码: 

ll ksm(int a,int b)//a的b次幂
{
	if (b == 1)return (ll)a;
	ll tmp = ksm(a, b / 2);
	if (b % 2) return tmp * tmp * a;
	else return tmp * tmp;
}

void solve()
{
	ll x;
	cin >> x;
	x--;
	ll cursum = 1;
	int curn = 1;
	vector<int>ans;
	ans.push_back(curn++);
	while (cursum <= x)//快速逼近
	{
		cursum = cursum * 2 + 1;
		if(cursum<=x)
		ans.push_back(curn++);
	}
	if (cursum > x)//二进制拆分补充
	{
		curn--;

		cursum = (cursum - 1) / 2;
		cursum = x - cursum;
		//补
		//求个最大值快速幂吧,顺便当复习了
		ll val = ksm(2, curn);
		int curvaln = curn+1;
		while (cursum > 0)
		{
			if (val <= 0)
			{
				cout << "impossible!!!";
				exit(-1);
			}

			if (val <= cursum)
			{
				ans.push_back(curvaln);
				cursum -= val;
			}
			val /= 2;
			curvaln--;
		}
	}
	cout << ans.size() << endl;
	for (auto num : ans)
	{
		cout << num << " ";
	}
	cout << endl;
}

到了这里,关于Educational Codeforces Round 161 (Rated for Div. 2) E. Increasing Subsequences 动态规划逼近,二进制拆分补充,注意严格递增的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Educational Codeforces Round 148 (Rated for Div. 2) 题解

    总结:5.21下午VP一场,死在了A题,给我wa崩溃了,浪费了差不多一个小时,BC还挺顺畅,虽然C题是在结束后不久交上去的。。。。 思路:其实思路很简单, “ The string s a palindrome ”, 题目已经说了所给的为回文字符串,所以直接判断一半 有几种字符 即可(开始的时候计算整

    2024年02月06日
    浏览(36)
  • Educational Codeforces Round 154 (Rated for Div. 2)(A—C)

    从1到9,每个数后面都可以加一个数构成一个含有两个数的质数,只需要从s[1]~s[9]中找到一个数与s[0]构成质数即可 观察样例即可发现两个字符串只要在相同位置都有 01 存在就能成功实现转换后两个字符串相等 可以先假设字符串是可以成立的,那么接下来就判断它什么时间是

    2024年02月10日
    浏览(39)
  • Educational Codeforces Round 154 (Rated for Div. 2)(A—D)

    从1到9,每个数后面都可以加一个数构成一个含有两个数的质数,只需要从s[1]~s[9]中找到一个数与s[0]构成质数即可 观察样例即可发现两个字符串只要在相同位置都有 01 存在就能成功实现转换后两个字符串相等 可以先假设字符串是可以成立的,那么接下来就判断它什么时间是

    2024年02月10日
    浏览(35)
  • Educational Codeforces Round 62 (Rated for Div. 2) C. Playlist

     一开始肯定要排个序,b相同时t大的在前边,不同时b大的在前面。 然后想最多只能选k个的限制,可以这样想,每次用到的b只能用已选到的最小的值,那可以把每个b都枚举一遍,然后每一次选时长最长的,且b大于等于当前的b的那k个不就好了吗,时间复杂度也才O(n),然

    2024年02月12日
    浏览(39)
  • Educational Codeforces Round 135 (Rated for Div. 2)C. Digital Logarithm(思维)

    C. Digital Logarithm 给两个长度位 n n n 的数组 a a a 、 b b b ,一个操作 f f f 定义操作 f f f 为, a [ i ] = f ( a [ i ] ) = a [ i ] a[i]=f(a[i])=a[i] a [ i ] = f ( a [ i ]) = a [ i ] 的位数 求最少多少次操作可以使 a 、 b a、b a 、 b 两个数组变得完全相同 性质: 对于任何数,经过两次操作我们一定可以

    2024年02月20日
    浏览(37)
  • 【每日一题】—— B. Ternary String (Educational Codeforces Round 87 (Rated for Div. 2))

    🌏博客主页: PH_modest的博客主页 🚩当前专栏: 每日一题 💌其他专栏: 🔴 每日反刍 🟡 C++跬步积累 🟢 C语言跬步积累 🌈座右铭: 广积粮,缓称王! 题目大意:给你一串由1、2、3组成的数组,让你求一个最短的子串,要求这个子串包含1、2、3 题目链接:B. Ternary String

    2024年02月16日
    浏览(37)
  • Educational Codeforces Round 157 (Rated for Div. 2) F. Fancy Arrays(容斥+组合数学)

    题目 称一个长为n的数列a是fancy的,当且仅当: 1. 数组内至少有一个元素在[x,x+k-1]之间 2. 相邻项的差的绝对值不超过k,即 t(t=50)组样例,每次给定n(1=n=1e9),x(1=x=40), 求fancy的数组的数量,答案对1e9+7取模 思路来源 灵茶山艾府群 官方题解 题解 看到 至少 的字眼,首先想到容斥,

    2024年02月05日
    浏览(39)
  • Educational Codeforces Round 145 Div. 2 题解

    目录 A. Garland(签到) 题面翻译 思路: 代码 B. Points on Plane(数学) 题面翻译 思路: 代码 C. Sum on Subarray(构造) 题面翻译: 思路: 代码 D. Binary String Sorting 题面翻译 思路: 代码 You have a garland consisting of 4 colored light bulbs, the color of the i-th light bulb is si. Initially, all the l

    2023年04月09日
    浏览(38)
  • Educational Codeforces Round 147 div2题解

    目录 A. Matching(签到) 思路: 代码:  B. Sort the Subarray(签到) 思路: 代码: C. Tear It Apart(枚举) 思路: 代码: D. Black Cells(模拟) 思路:  代码一: 代码二:(模仿自\\\"AG\\\"佬) An integer template is a string consisting of digits and/or question marks. A positive (strictly greater than 0) in

    2023年04月21日
    浏览(39)
  • Educational Codeforces Round 134 (Div.2) D 题解

    D. Maximum AND 给定两组序列 (a) (b) ,长度为 (n) ,现有一新序列 (c) ,长度也为 (n) 。 其中, (c_i = a_i oplus b_i) 。 定义 (f(a,b) = c_1c_2……c_n) 。 现在你可以随意编排 (b) 序列的顺序,求 (f(a,b)) 的最大值。 以下位运算均是二进制。 由于按位与的运算结果是越来越小的

    2024年02月06日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包