晨哥Leetcode 522.最长非公共子序列之2 · Longest Uncommon Subsequence II

给定一组字符串,你需要找到这组字符串中最长的非公共子序列。 最长的非公共子序列被定义为这些字符串之一的最长子序列,并且此子序列不应该是其他字符串的子序列。
子序列是可以通过删除一些字符而不改变其余元素的顺序从一个序列导出的序列。可以说,任何字符串都是自身的子序列,空字符串是任何字符串的子序列。
输入将是字符串列表,输出需要是最长的非公共子序列的长度。 如果最长的非公共子序列不存在,则返回-1。

这题很容易搞错,题目有点难以理解
搞清楚子序列和子串的区别!子序列不需要连续,所以用str.contains(str2)是不行的
通过前面的题最长非公共子序列之1 我们知道,只要两个字符串不相等,那最长的字符串就是所求的解
但是我们不能用同样的思路来做这题,不能因为两个字符串相等就把它删掉,因为其他小的字符串可能是他们的子序列,也是不能作为解的
其实这题的做法有点类似于Brute force,直接判断每个子串是不是其他字符串的子序列,最长的子串满足这个要求的就是解。
没什么花样,只是理解题意上比较困难,也容易想走捷径

判断是不是子序列的基本功: 双指针

private boolean isSubsequence(String a, String b) {//a是b的子序列吗?
        int i = 0;
        for(int j = 0; i < a.length() && j < b.length(); j++) {
            if(a.charAt(i) == b.charAt(j)) {
                i++;
            }
        }
        return i == a.length();
    }
```
如果a比b的长度大,那a就不可能是b的子序列,这个判断我放在for 循环里了:
```
public int findLUSlength(String[] strs) {
        Arrays.sort(strs, (a, b) -> b.length() - a.length());//从长到短排列
        for(int i = 0; i < strs.length; i++) {
            boolean flag = true;
            for(int j=0; j < strs.length && strs[i].length() <= strs[j].length(); j++) {
                if(i == j) continue;
                if(isSubsequence(strs[i], strs[j])) {
                    flag = false;
                    break;
                }
            }
            if(flag) {
                return strs[i].length();
            }
        }
        return -1;
    }
```
### 关于ArcGIS License Server无法启动的解决方案 当遇到ArcGIS License Server无法启动的情况,可以从以下几个方面排查并解决问题: #### 1. **检查网络配置** 确保License Server所在的计算机能够被其他客户端正常访问。如果是在局域网环境中部署了ArcGIS Server Local,则需要确认该环境下的网络设置是否允许远程连接AO组件[^1]。 #### 2. **验证服务状态** 检查ArcGIS Server Object Manager (SOM) 的运行情况。通常情况下,在Host SOM机器上需将此服务更改为由本地系统账户登录,并重启相关服务来恢复其正常工作流程[^2]。 #### 3. **审查日志文件** 查看ArcGIS License Manager的日志记录,寻找任何可能指示错误原因的信息。这些日志可以帮助识别具体是什么阻止了许可服务器的成功初始化。 #### 4. **权限问题** 确认用于启动ArcGIS License Server的服务账号具有足够的权限执行所需操作。这包括但不限于读取/写入特定目录的权利以及与其他必要进程通信的能力。 #### 5. **软件版本兼容性** 保证所使用的ArcGIS产品及其依赖项之间存在良好的版本匹配度。不一致可能会导致意外行为完全失败激活license server的功能。 #### 示例代码片段:修改服务登录身份 以下是更改Windows服务登录凭据的一个简单PowerShell脚本例子: ```powershell $serviceName = "ArcGISServerObjectManager" $newUsername = ".\LocalSystemUser" # 替换为实际用户名 $newPassword = ConvertTo-SecureString "" -AsPlainText -Force Set-Service -Name $serviceName -StartupType Automatic New-ServiceCredential -ServiceName $serviceName -Account $newUsername -Password $newPassword Restart-Service -Name $serviceName ``` 上述脚本仅作为示范用途,请依据实际情况调整参数值后再实施。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值