???477 2017-01-22 12:52 采纳率: 100%
浏览 971
已采纳

在线等,Java 小白诚求编写一道很简单的算法题,立即给分

之前提过相同问题,但当时没仔细看结果就立即采纳了,刚发现答案是错的。

一道大学算法考试题,我没好好学java,现在求大神帮忙,编写出来能运行出正确结果立即采纳.

一个由N个括号组成的字符串S,开括号” ( “ 和闭括号 “ ) “ ,目标是将S分成两个部分,使得第一部分中的开放括号的数量等于第二部分中的闭合括号的数量。
更正式地说,我们正在寻找一个整数K
0 <= K <= N,
S的前k个字符中的开括号的数目与S的后面 (N - K)个字符中的闭括号的数目相同。
例如,给定S = “ ( ( ) ) ) ) ( ”,K等于4,因为:
S的前四个字符“ ( ( ) ) ”,包含两个开括号
S的剩余三个字符“ ) ) ( ”,包含两个闭括号。
写一个函数
class Solution {public int solution(string S); }
给定字符串S,返回满足上述条件的K的值。(K总是存在并且是唯一的)。
例如,给定S =“(( ))))(”,函数应该返回4,如上所述。
假设:
N是在范围[0 ... 100,000]内的整数,
字符串S仅由字符“(” 或“ ) ”组成。

  • 写回答

3条回答

  • Littlechoc 2017-01-22 14:28
    关注
        public int solution(String input) {
            if (input == null || input.length() == 0) {
                return -1; // Input Error
            }
    
            // Step1: 统计开闭括号个数
            int leftTotal = 0; // 开括号个数
            for (int i = 0; i < input.length(); i++) {
                char ch = input.charAt(i);
                if (ch == '(') {
                    leftTotal++;
                } else if (ch == ')') {
                    // Do nothing
                } else {
                    return -1; // Input Error
                }
            }
            int rightTotal = input.length() - leftTotal; // 闭括号个数
    
            // Step2: 遍历计算
            int leftCount = 0;
            for (int i = 1; i <= input.length(); i++) {
                char ch = input.charAt(i - 1);
                if (ch == '(') {
                    leftCount++;
                }
                int rightCount = rightTotal - (i - leftCount); // 关键
                if (rightCount == leftCount) { // Success
                    return i;
                }
            }
    
            return 0; // Not Found
        }
    
    

    NOTE:输入里不要出现空格

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3