最长公共子序列问题

构造最长公共子序列为什么要这样构造序列

cpp 复制代码
 for(int i=1;i<=n;++i)
    {
        int k;
        cin>>k;
        b[k]=i;
    }
    for(int i=1;i<=n;++i)
    {
   	    int k;
    	cin>>k;
    	a[i]=b[k];
    }

并且为什么要求上升序列,是有什么数学知识包含在其中吗?

为什么在求最长公共子序列时,f[mid]大于等于或大于a[i]都可以,而在最长单调上升子序列中只能大于等于,不能大于

cpp 复制代码
   for(int i=1;i<=n;++i)
    {
	    if(f[ans]<a[i]) f[++ans]=a[i];
	    else
	    {
 	        int l=1,r=ans;
 	        while(l<r)
  	        { 
        	    int mid=(l+r)>>1;
        	    if(f[mid]>a[i]) r=mid;
                else l=mid+1;   
            }
            f[l]=a[i];
        }
}
相关推荐
C++ 老炮儿的技术栈17 分钟前
不调用C++/C的字符串库函数,编写函数strcpy
c语言·开发语言·c++·windows·git·postman·visual studio
我尽力学18 分钟前
面试 总结
java·spring boot·面试
爬台阶的蚂蚁22 分钟前
Spring AI Alibaba基础概念
java·spring·ai
布局呆星23 分钟前
闭包与装饰器
开发语言·python
Σίσυφος190024 分钟前
Halcon中霍夫直线案例
算法
计算机学姐31 分钟前
基于SpringBoot的演唱会抢票系统
java·spring boot·后端·spring·tomcat·intellij-idea·推荐算法
fyzy34 分钟前
C++写后端实现,实现前后端分离
开发语言·c++
huohuopro36 分钟前
Mybatis的七种传参方式
java·开发语言·mybatis
Lee_SmallNorth38 分钟前
变态需求之【角色不同访问数据库的用户不同】
java·开发语言·数据库
扶苏-su39 分钟前
Java网络编程:InetAddress 详解
java·开发语言·网络