LeetCode 第 149 场周赛

一、一年中的第几天(LeetCode-1154)

1.1 题目描述

1.2 解题思路

比较水的一题,搞清楚平年、闰年的判定规则,就很容易做出来。

1.3 解题代码


class Solution {

    public int ordinalOfDate(String date) {
        String[] dateArray = date.split("-");
        int year = Integer.parseInt(dateArray[0]);
        int month = Integer.parseInt(dateArray[1]);
        int day = Integer.parseInt(dateArray[2]);
        int totalDay = 0;
        for (int i = 1; i < month; i++) {
            totalDay += getDay(year, i);
        }
        totalDay += day;
        return totalDay;
    }

    private int getDay(int year, int month) {
        int[] datyOf12Month = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
        return month == 2 && isLeepYear(year) ? datyOf12Month[month] + 1 : datyOf12Month[month];
    }

    //是否是闰年 是 29天 ,不是 28天
    private boolean isLeepYear(int year) {
        if (year % 100 == 0) {
            return year % 4 == 0;
        }
        return year % 4 == 0;
    }

}

二、掷骰子的N种方法(LeetCode-1155)

2.1 题目介绍

这里有?d?个一样的骰子,每个骰子上都有?f?个面,分别标号为?1, 2, ..., f。

我们约定:掷骰子的得到总点数为各骰子面朝上的数字的总和。

如果需要掷出的总点数为?target,请你计算出有多少种不同的组合情况(所有的组合情况总共有 f^d 种),模?10^9 + 7?后返回。

2.2 解题思路

该题属于计数型动态规划

根据题意,设dp[d][target]是用掷d个骰子,骰子的面数f,得到和为target的方法数。

假设d=3,f=5,target = 19

(1)最后一步:

d[3][19] = d[2][19-1] +  d[2][19-2] +  d[2][19-3] +  d[2][19-4] +  d[2][19-5]

由于 d[3][19]初始化为0,所以上面的公式可以简化为

for (i = 1;i<5;i++)
    d[3][19] += d[3-1][19 - i]

(2)初始条件

当只有一个骰子时,有f个面,我们知道获得x(1<=x<=f)的方法均为1种。

所以

for(i=1;i<f;i++)
    dp[1][i] = 1 

(3)状态转移方程

for(i = 2;i<=d;i++)
    for(j = 1;j<=target;j++)
        for (k = 1;k<=f;k++)
            // j>=k
            dp[i][j] += d[i-1][j-k]

(4)边界

循环结束,i = d,j = target,即到达边界点,也就求出解。

2.3 解题代码


public int numRollsToTarget(int d, int f, int target) {
        int[][] dp = new int[d+1][1001];
        //初始化条件,只有1个骰子的时候,1-f的方法均只有1种
        for (int i = 1; i <= f; i++) {
            dp[1][i] = 1;
        }
        //骰子数
        for (int i = 2; i <= d; i++) {
            //要凑出的面值
            for (int j = 1; j <= target; j++) {
                //骰子面值
                for (int k = 1; k <= f; k++) {
                    if (j >= k) {
                        dp[i][j] += dp[i - 1][j - k];
                        dp[i][j] %= 1000000007;
                    }
                }
            }
        }
        return dp[d][target];
    }

原文地址:https://www.cnblogs.com/fonxian/p/11405786.html

时间: 2024-08-29 17:13:28

LeetCode 第 149 场周赛的相关文章

LeetCode 第 165 场周赛

LeetCode 第 165 场周赛 5275. 找出井字棋的获胜者 5276. 不浪费原料的汉堡制作方案 5277. 统计全为 1 的正方形子矩阵 5278. 分割回文串 III C 暴力做的,只能说数据不充分 找出井字棋的获胜者4 题目描述 Description A 和 B 在一个 3 x 3 的网格上玩井字棋. 井字棋游戏的规则如下: 玩家轮流将棋子放在空方格 (" ") 上. 第一个玩家 A 总是用 "X" 作为棋子,而第二个玩家 B 总是用 "

Leetcode 第174场周赛 题解

Leetcode 第174场周赛 题解 方阵中战斗力最弱的 K 行 签到题,统计一下每行的军人数量,然后设置一下排序规则即可. 时间复杂度 \(O(nlogn)\) typedef long long ll; typedef double db; #define _for(i,a,b) for(int i = (a);i < b;i ++) #define _rep(i,a,b) for(int i = (a);i > b;i --) #define INF 0x3f3f3f3f3f3f3f3

Leetcode 第175场周赛 题解(完结)

Leetcode 第175场周赛 题解 检查整数及其两倍数是否存在 数据范围小的可怜,\(O(n^2)\) 解法可行.如果范围大一点,可以先进行排序然后遍历每一个数进行二分查找,时间复杂度 \(O(nlogn)\) 代码是平方解法. typedef long long ll; typedef double db; #define _for(i,a,b) for(int i = (a);i < b;i ++) #define _rep(i,a,b) for(int i = (a);i > b;i

LeetCode 第 183 场周赛

LeetCode 第 183 场周赛 非递增顺序的最小子序列 降序排列后,往 vector<int>ans 中添加元素,直到其和超过所有元素和的一半. class Solution { public: vector<int> minSubsequence(vector<int>& nums) { const int n = nums.size(); sort(nums.begin(), nums.end(), greater<int>()); int

LeetCode第136场周赛

菜鸡我只做出了一道... 5055. 困于环中的机器人 在无限的平面上,机器人最初位于 (0, 0) 处,面朝北方.机器人可以接受下列三条指令之一: "G":直走 1 个单位 "L":左转 90 度 "R":右转 90 度 机器人按顺序执行指令 instructions,并一直重复它们. 只有在平面中存在环使得机器人永远无法离开时,返回 true.否则,返回 false. 提示: 1 <= instructions.length <=

LeetCode 第133场周赛总结

1029. 两地调度 公司计划面试 2N 人.第 i 人飞往 A 市的费用为 costs[i][0],飞往 B 市的费用为 costs[i][1]. 返回将每个人都飞到某座城市的最低费用,要求每个城市都有 N 人抵达. 示例: 输入:[[10,20],[30,200],[400,50],[30,20]] 输出:110 解释: 第一个人去 A 市,费用为 10. 第二个人去 A 市,费用为 30. 第三个人去 B 市,费用为 50. 第四个人去 B 市,费用为 20. 最低总费用为 10 + 30

LeetCode 第 155 场周赛

成绩 第二题尝试了两种解法,一种超时间.一种超内存,只AC了一题.归根结底还是太菜. 一.最小绝对差(LeetCode-5189) 1.1 题目描述 1.2 解题思路 数组排好序,获取最小的差值即可. 1.3 解题代码 public class Solution { class Test { public List<Integer> list; public Integer num; } public List<List<Integer>> minimumAbsDiff

leetcode第 181 场周赛

5364. 按既定顺序创建目标数组 给你两个整数数组 nums 和 index.你需要按照以下规则创建目标数组: 目标数组 target 最初为空. 按从左到右的顺序依次读取 nums[i] 和 index[i],在 target 数组中的下标 index[i] 处插入值 nums[i] . 重复上一步,直到在 nums 和 index 中都没有要读取的元素. 请你返回目标数组. 题目保证数字插入位置总是存在. 示例 1: 输入:nums = [0,1,2,3,4], index = [0,1,

leetcode 第184场周赛第一题(数组中的字符串匹配)

一.函数的运用 1,strstr(a,b); 判断b是否为a的子串,如果是,返回从b的开头开始到a的结尾 如“abcdefgh” “de” 返回“defgh”: 如果不是子串,返回NULL: 2,memcpy(a,b+n,c); 将b串从第n位后的c个字符串复制到a中,返回a串: (注:做完函数后需要添加上b[c] = '\0') 如果吧b+n换成b就是从头开始 将代码换成 memcpy(arr[cnt], words[i], strlen(words[i])+1); 就是直接复制words[i