180713

Excel表列序号

题目描述

给定一个Excel表格中的列名称,返回其相应的列序号。

例如,

A -> 1
B -> 2
C -> 3
...
Z -> 26
AA -> 27
AB -> 28 
...

示例 1:

输入: “A”
输出: 1
示例 2:

输入: “AB”
输出: 28
示例 3:

输入: “ZY”
输出: 701

思路:

这个题就是26进制转10进制,没什么难的。

代码

class Solution {
public:
    int titleToNumber(string s) {
        int flag = 1;
        int ret = 0;
        int tmp;
        for(int i = s.size()-1;i>=0;i--)
        {
            tmp = (s[i] - 'A')+1;
            tmp = tmp*flag;
            ret += tmp;
            flag *= 26;
        }
        
        return ret;
        
    }
};

写字符串需要的行数

题目描述

我们要把给定的字符串 S 从左到右写到每一行上,每一行的最大宽度为100个单位,如果我们在写某个字母的时候会使这行超过了100 个单位,那么我们应该把这个字母写到下一行。我们给定了一个数组 widths ,这个数组 widths[0] 代表 ‘a’ 需要的单位, widths[1] 代表 ‘b’ 需要的单位,…, widths[25] 代表 ‘z’ 需要的单位。

现在回答两个问题:至少多少行能放下S,以及最后一行使用的宽度是多少个单位?将你的答案作为长度为2的整数列表返回。

示例 1:
输入:
widths = [10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10]
S = “abcdefghijklmnopqrstuvwxyz”
输出: [3, 60]
解释:
所有的字符拥有相同的占用单位10。所以书写所有的26个字母,
我们需要2个整行和占用60个单位的一行。
示例 2:
输入:
widths = [4,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10]
S = “bbbcccdddaaa”
输出: [2, 4]
解释:
除去字母’a’所有的字符都是相同的单位10,并且字符串 “bbbcccdddaa” 将会覆盖 9 * 10 + 2 * 4 = 98 个单位.
最后一个字母 ‘a’ 将会被写到第二行,因为第一行只剩下2个单位了。
所以,这个答案是2行,第二行有4个单位宽度。

注:

字符串 S 的长度在 [1, 1000] 的范围。
S 只包含小写字母。
widths 是长度为 26的数组。
widths[i] 值的范围在 [2, 10]。

思路

思路很简单,看代码应该就能明白

代码

class Solution {
public:
    vector<int> numberOfLines(vector<int>& widths, string S) 
    {
        int n=S.size(),lines=1,pos=0;
        for(int i=0;i<n;i++)
        {
            pos += widths[S[i]-'a'];
            if(pos>100) //写出头了
            {
                lines++;pos=0;//往下一行写
                i--;//就当没写过这个单词
            }
        }
        return {lines,pos};
    }
};

岛屿的周长

题目描述

给定一个包含 0 和 1 的二维网格地图,其中 1 表示陆地 0 表示水域。网格中的格子水平和垂直方向相连(对角线方向不相连)。整个网格被水完全包围,但其中恰好有一个岛屿(或者说,一个或多个表示陆地的格子相连组成的岛屿)。岛屿中没有“湖”(“湖” 指水域在岛屿内部且不和岛屿周围的水相连)。格子是边长为 1 的正方形。网格为长方形,且宽度和高度均不超过 100 。计算这个岛屿的周长。

示例 :

[[0,1,0,0],
[1,1,1,0],
[0,1,0,0],
[1,1,0,0]]

答案: 16

思路

看看四周有没有小格子,有的话,执行-1操作。

代码

class Solution {
public:
    int islandPerimeter(vector<vector<int>>& grid) {
        if (grid.empty() || grid[0].empty()) return 0;
        int res = 0, m = grid.size(), n = grid[0].size();
        for (int i = 0; i < m; ++i) {
            for (int j = 0; j < n; ++j) {
                if (grid[i][j] == 0) continue;
                res += 4;
                if (i > 0 && grid[i - 1][j] == 1) res -= 2;
                if (j > 0 && grid[i][j - 1] == 1) res -= 2;
            }
        }
        return res;
    }
};
    原文作者:美不胜收oo
    原文地址: https://www.jianshu.com/p/19b082600ead
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞