Heim  >  Artikel  >  Web-Frontend  >  Zwei algorithmische Fragen zum Dreieck- und Klammer-Matching von Yang Hui

Zwei algorithmische Fragen zum Dreieck- und Klammer-Matching von Yang Hui

一个新手
一个新手Original
2017-09-20 10:30:411259Durchsuche

1. Geben Sie eine Zahl ein und bestimmen Sie, um welche Zeile es sich im Dreieck von Yang Hui handelt
Wichtige Punkte: Zweidimensionales Array

function fun(item) {
        if(item===1) return 1;        
        var arr = [];        
        for(var i=0;;i++) {
            arr[i] = [];            
            for (var j = 0; j <= i; j++) {                
            if (i == j || j == 0) {
                    arr[i][j] = 1
                } else {
                    arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];                    
                    if(arr[i][j] ==item){                        
                    return i+1;
                    }
                }
            }
        }
    }

2. Geben Sie eine Reihe von Klammern wie folgt ein:
Zwei algorithmische Fragen zum Dreieck- und Klammer-Matching von Yang Hui

 function check(str) {
        var arr = str.split(&#39;&#39;); // 将传入字符串转化为数组
        var stack = new Array(); // 新建栈,这里我用数组代替
        var aString = &#39;({[]})&#39; ; // 用来匹配的字符串
        var index = -1;          //初始化下标
        for (var i = 0; i < arr.length; i++) {            
        var item = arr[i];            
        if ((index = aString.indexOf(item)) < 3) {   // 将每一项都用aString匹配,下标小于3就是左括号
                // 左括号,入栈
                stack.push(item)
            } else {                //  右括号,栈列表出栈一个元素与之匹配
                var target = stack.pop();                //  如果出栈元素不存在,则这个右括号没有响应匹配的左括号,验证失败
                if (!target) {                    return false
                }                // 取出与 item 对应的左括号与出栈元素匹配,不相等则验证失败
                if (target !== aString.charAt(5-index)) {                    
                return false
                }
            }
        }        //  循环匹配完成后,如果栈列表还有元素,则缺少与之匹配的右括号,验证失败
        if (stack.length) {            
        return false
        }        //  ok
        return true
    }

Das obige ist der detaillierte Inhalt vonZwei algorithmische Fragen zum Dreieck- und Klammer-Matching von Yang Hui. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn