国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

代碼隨想錄day2|有序數(shù)組的平方、長度最小的子數(shù)組、螺旋矩陣

這篇具有很好參考價值的文章主要介紹了代碼隨想錄day2|有序數(shù)組的平方、長度最小的子數(shù)組、螺旋矩陣。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

前言:今天去校醫(yī)院拔了兩顆牙,太痛了,今天寫的博客就比較水。

1、有序數(shù)組的平方(雙指針法)

代碼隨想錄day2|有序數(shù)組的平方、長度最小的子數(shù)組、螺旋矩陣

class Solution {
public:
    vector<int> sortedSquares(vector<int>& nums) {
        int k = nums.size() - 1;
        vector<int> result(nums.size(),0);//創(chuàng)造一個數(shù)組result長度與nums相同
        for(int i = 0, j = nums.size() -1;i <= j;)
        {
            if(nums[i]*nums[i] < nums[j]*nums[j])
            {
                result[k--] = nums[j]*nums[j];
                j--;
            }else{
                result[k--] = nums[i]*nums[i];
                i++;
            }
        }
        return result;
    }
};

2、 長度最小的子數(shù)組(滑動窗口)

代碼隨想錄day2|有序數(shù)組的平方、長度最小的子數(shù)組、螺旋矩陣

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int result = INT32_MAX;//返回值
        int i = 0;//滑動窗口的起始位置
        int sum = 0;//子數(shù)組中元素之和
        int subLength = 0;//滑動窗口的長度
        for(int j = 0;j < nums.size();j++)//將j設置成終止元素
        {
            sum += nums[j];
            while(sum >= target)
            {
                subLength = j - i + 1;
                sum -= nums[i];
                i++;
                result = result < subLength ? result : subLength;
            }
        }
        return result == INT32_MAX ? 0 : result;
    }
};

所謂滑動窗口,就是不斷的調(diào)節(jié)子序列的起始位置和終止位置,從而得出我們要想的結(jié)果。

3、 螺旋矩陣

代碼隨想錄day2|有序數(shù)組的平方、長度最小的子數(shù)組、螺旋矩陣文章來源地址http://www.zghlxwxcb.cn/news/detail-427327.html

class Solution {
public:
    vector<vector<int>> generateMatrix(int n) {
        vector<vector<int>> result(n,vector<int>(n,0));//使用vector容器定義一個二維數(shù)組
        int startx = 0,starty = 0;//定義起始點坐標是(0,0)
        int offset = 1;//設定偏移量為1
        int count = 1;
        int loop = n / 2;
        int mid = n/2;
        while(loop--)//偶數(shù),轉(zhuǎn)n/2圈;奇數(shù),轉(zhuǎn)n/2+1圈(等一會判斷一下)
        {
            int i = startx;
            int j = starty;
            //遵循左閉右開,設定有i行,j列
            for(j = starty;j < n - offset;j++)// 從左到右處理
            {
                result[startx][j] = count++;
            }
            for(i = startx;i < n - offset;i++)// 從上到下處理
            {
                result[i][j] = count++;
            }
            for(;j > starty;j--)// 從右到左處理
            {
                result[i][j] = count++;
            }
            for(;i > startx;i--)// 從下到上處理
            {
                result[i][j] = count++;
            }
            startx++;
            starty++;
            offset++;
        }
        if(n % 2)
        {
            result[mid][mid] = count;
        }
        return result;
    }
};

到了這里,關于代碼隨想錄day2|有序數(shù)組的平方、長度最小的子數(shù)組、螺旋矩陣的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包