大家好,我叫亓官劼(qí guān jié ),在CSDN中记录学习的点滴历程,时光荏苒,未来可期,加油~博主目前仅在CSDN中写博客,唯一博客更新的地址为:亓官劼的博客
本文原创为亓官劼,请大家支持原创,部分平台一直在恶意盗取博主的文章!!!
本次比赛只过了2题,第三题卡了一下边缘情况,调了一个多小时,然后比赛已经结束了,第四题还没开。
排名 1362/5474 位次在24%这样子
好久没写比赛了,退步了不少。
给你一个整数数组 arr
,以及 a
、b
、c
三个整数。请你统计其中好三元组的数量。
如果三元组 (arr[i], arr[j], arr[k])
满足下列全部条件,则认为它是一个 好三元组 。
0 <= i < j < k < arr.length
|arr[i] - arr[j]| <= a
|arr[j] - arr[k]| <= b
|arr[i] - arr[k]| <= c
其中 |x|
表示 x
的绝对值。
返回 好三元组的数量 。
示例 1:
输入:arr = [3,0,1,1,9,7], a = 7, b = 2, c = 3
输出:4
解释:一共有 4 个好三元组:[(3,0,1), (3,0,1), (3,1,1), (0,1,1)] 。
示例 2:
输入:arr = [1,1,2,2,3], a = 0, b = 0, c = 1
输出:0
解释:不存在满足所有条件的三元组。
提示:
3 <= arr.length <= 100
0 <= arr[i] <= 1000
0 <= a, b, c <= 1000
打卡题我就直接暴力了。
class Solution {
public:
int countGoodTriplets(vector<int>& arr, int a, int b, int c) {
int len = arr.size();
int ans = 0;
for(int i = 0; i < len ; i++){
for(int j = i+1 ; j < len ; j++){
for(int k = j+1; k< len; k++){
if(abs(arr[i] - arr[j]) <= a && abs(arr[j] - arr[k]) <= b && abs(arr[i] - arr[k]) <= c)
ans++;
}
}
}
return ans;
}
};
给你一个由 不同 整数组成的整数数组 arr
和一个整数 k
。
每回合游戏都在数组的前两个元素(即 arr[0]
和 arr[1]
)之间进行。比较 arr[0]
与 arr[1]
的大小,较大的整数将会取得这一回合的胜利并保留在位置 0
,较小的整数移至数组的末尾。当一个整数赢得 k
个连续回合时,游戏结束,该整数就是比赛的 赢家 。
返回赢得比赛的整数。
题目数据 保证 游戏存在赢家。
示例 1:
输入:arr = [2,1,3,5,4,6,7], k = 2
输出:5
解释:一起看一下本场游戏每回合的情况:
因此将进行 4 回合比赛,其中 5 是赢家,因为它连胜 2 回合。
示例 2:
输入:arr = [3,2,1], k = 10
输出:3
解释:3 将会在前 10 个回合中连续获胜。
示例 3:
输入:arr = [1,9,8,2,3,7,6,4,5], k = 7
输出:9
示例 4:
输入:arr = [1,11,22,33,44,55,66,77,88,99], k = 1000000000
输出:99
提示:
2 <= arr.length <= 10^5
1 <= arr[i] <= 10^6
arr
所含的整数 各不相同 。1 <= k <= 10^9
这里我们切记不要真实的去移动数组,这里只需要模拟移动即可,我们通过双指针来指向相应的位置即可。
class Solution {
public:
int getWinner(vector<int>& arr, int k) {
int len = arr.size();
if(k >= len){
// 返回最大值
sort(arr.begin(),arr.end());
if(arr[0] >= arr[len-1]){
return arr[0];
}else
return arr[len-1];
}
int i,j,cnt,ans;
cnt = 0;
ans = -0x7f7f7f7f;
for(i = 0, j = 1;i < len && j < len && cnt < k;){
if(arr[i] >= arr[j]){
if(arr[i] == ans){
cnt++;
}else{
ans = arr[i];
cnt = 1;
}
j++;
}else{
if(arr[j] == ans){
cnt++;
}else{
ans = arr[j];
cnt = 1;
}
i = j;
j++;
}
}
return ans;
}
};
给你一个 n x n
的二进制网格 grid
,每一次操作中,你可以选择网格的 相邻两行 进行交换。
一个符合要求的网格需要满足主对角线以上的格子全部都是 0 。
请你返回使网格满足要求的最少操作次数,如果无法使网格符合要求,请你返回 -1 。
主对角线指的是从 (1, 1)
到 (n, n)
的这些格子。
示例 1:
输入:grid = [[0,0,1],[1,1,0],[1,0,0]]
输出:3
示例 2:
输入:grid = [[0,1,1,0],[0,1,1,0],[0,1,1,0],[0,1,1,0]]
输出:-1
解释:所有行都是一样的,交换相邻行无法使网格符合要求。
示例 3:
输入:grid = [[1,0,0],[1,1,0],[1,1,1]]
输出:0
提示:
n == grid.length
n == grid[i].length
1 <= n <= 200
grid[i][j]
要么是 0
要么是 1
。这题在比赛中没写完就结束了,卡死在了一个<=
的边界。。。
这题的话和第二题一样,也是不能真的移动,而是要模拟,这里只需要我们移动行,使得我们的主对角线上方都是0,那么我们只需要使用一个数组来记录每一行右面连续0的个数,然后我们来使用这个数组来进行模拟即可。
class Solution {
public:
int minSwaps(vector<vector<int>>& grid) {
int n = grid.size();
vector<int> zero_cnt(n);
for (int i = 0; i < n; ++i) {
int cnt = 0;
for (int j = n - 1; j >= 0; --j) {
if (grid[i][j] == 0) {
++cnt;
} else {
break;
}
}
zero_cnt[i] = cnt;
}
int res = 0;
for (int i = 0; i < n; ++i) {
if (zero_cnt[i] >= n - i - 1)
continue;
int j = i + 1;
for (; j < n; ++j) {
if (zero_cnt[j] >= n - i - 1)
break;
}
if (j == n) return -1;
res += j - i;
rotate(zero_cnt.begin() + i, zero_cnt.begin() + j, zero_cnt.begin() + j + 1);
}
return res;
}
};
你有两个 有序 且数组内元素互不相同的数组 nums1
和 nums2
。
一条 合法路径 定义如下:
nums1
和 nums2
中都存在的值,那么你可以切换路径到另一个数组对应数字处继续遍历(但在合法路径中重复数字只会被统计一次)。得分定义为合法路径中不同数字的和。
请你返回所有可能合法路径中的最大得分。
由于答案可能很大,请你将它对 10^9 + 7 取余后返回。
示例 1:
输入:nums1 = [2,4,5,8,10], nums2 = [4,6,8,9]
输出:30
解释:合法路径包括:
[2,4,5,8,10], [2,4,5,8,9], [2,4,6,8,9], [2,4,6,8,10],(从 nums1 开始遍历)
[4,6,8,9], [4,5,8,10], [4,5,8,9], [4,6,8,10] (从 nums2 开始遍历)
最大得分为上图中的绿色路径 [2,4,6,8,10] 。
示例 2:
输入:nums1 = [1,3,5,7,9], nums2 = [3,5,100]
输出:109
解释:最大得分由路径 [1,3,5,100] 得到。
示例 3:
输入:nums1 = [1,2,3,4,5], nums2 = [6,7,8,9,10]
输出:40
解释:nums1 和 nums2 之间无相同数字。
最大得分由路径 [6,7,8,9,10] 得到。
示例 4:
输入:nums1 = [1,4,5,8,9,11,19], nums2 = [2,3,4,11,12]
输出:61
提示:
1 <= nums1.length <= 10^5
1 <= nums2.length <= 10^5
1 <= nums1[i], nums2[i] <= 10^7
nums1
和 nums2
都是严格递增的数组。比赛的时候都卡在第三题上了,第四题没开。。。也就没写了,这里放一个第一大佬的写法,给大家参考下。
class Solution {
typedef long long ll;
const int P=1000000007;
public:
int maxSum(vector<int>& nums1, vector<int>& nums2) {
int n=nums1.size(),m=nums2.size(),i,j;
long long s1=0,s2=0;
for(i=n-1,j=m-1;~i&&~j;)if(nums1[i]>nums2[j])
{
s1+=nums1[i];
i--;
}
else if(nums1[i]<nums2[j])
{
s2+=nums2[j];
j--;
}
else
{
s1=s2=max(s1,s2)+nums1[i];
i--;
j--;
}
for(;~i;i--)s1+=nums1[i];
for(;~j;j--)s2+=nums2[j];
return max(s1,s2)%P;
}
};