力扣—2024 春招冲刺百题计划

2024-04-10 11:36

本文主要是介绍力扣—2024 春招冲刺百题计划,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

矩阵

1. 螺旋矩阵

代码实现:

/** @param matrix int整型二维数组 * @param matrixRowLen int matrix数组行数* @param matrixColLen int* matrix数组列数* @return int整型一维数组* @return int* returnSize 返回数组行数
*/
int* spiralOrder(int **matrix, int matrixRowLen, int *matrixColLen, int *returnSize) {int s = 0, x = matrixRowLen - 1, z = 0, y = *matrixColLen - 1; // s = 上, x = 下, z = 左, y = 右int len = matrixRowLen * *matrixColLen;int *arr = (int*)malloc(sizeof(int) * len);int count = 0;while (1) {for (int i = z; i <= y; i++) { // 从左到右arr[count++] = matrix[s][i];}if (count >= len) {break; }for (int i = s + 1; i < x; i++) { // 从上到下arr[count++] = matrix[i][y];}if (count >= len) {break;}for (int i = y; i >= z; i--) { // 从右到左arr[count++] = matrix[x][i];}if (count >= len) { break;}for (int i = x - 1; i > s; i--) { // 从下到上arr[count++] = matrix[i][z];}if (count >= len) {break;}s++;x--;z++;y--;}*returnSize = len;return arr;
}

2. 生命游戏

代码实现:

int dir[8][2] = {{-1, -1}, {-1, 0}, {-1, 1}, {0, -1}, {0, 1}, {1, -1}, {1, 0}, {1, 1}
};
int getLifeCellNum(int **board, int boardSize, int *boardColSize, int m, int n) {int i, j;int x, y;int result = 0;for (i = 0; i < 8; i++) {x = m + dir[i][0];y = n + dir[i][1];if ((x >= 0) && (x < boardSize) && (y >= 0) && (y < boardColSize[x])) {if (board[x][y] == 1) {result++;}}}return result;
}void gameOfLife(int **board, int boardSize, int *boardColSize) {int i, j;if ((board == NULL) || (boardSize == 0) || (boardColSize == NULL)) {return;}int **tmp = (int**)malloc(sizeof(int *) * boardSize);for (i = 0; i < boardSize; i++) {tmp[i] = (int*)malloc(sizeof(int) * boardColSize[i]);}for (i = 0; i < boardSize; i++) {for (j = 0; j < boardColSize[i]; j++) {tmp[i][j] = getLifeCellNum(board, boardSize, boardColSize, i, j);}}for (i = 0; i < boardSize; i++) {for (j = 0; j < boardColSize[i]; j++) {if (board[i][j]) {if ((tmp[i][j] != 2) && (tmp[i][j] != 3)) {board[i][j] = 0;}} else {if (tmp[i][j] == 3) {board[i][j] = 1;}}}}for (i = 0; i < boardSize; i++) {free(tmp[i]);}free(tmp);return;
}

3. 旋转图像

代码实现:

方法一:使用辅助数组

void rotate(int **matrix, int matrixSize, int *matrixColSize) {int a[matrixSize][matrixSize];for (int i = 0; i < matrixSize; i++) {for (int j = 0; j < matrixSize; j++) {a[i][j] = matrix[i][j];}}for (int i = 0; i < matrixSize; i++) {for (int j = 0; j < matrixSize; j++) {matrix[j][matrixSize - i - 1] = a[i][j];}}
}

方法二:先将矩阵(x, y)转置,在左右对称即可实现90度顺时针旋转

void rotate(int **matrix, int matrixSize, int *matrixColSize){// 先进行矩阵的转置for (int i = 0; i < matrixSize; i++){for (int j = i; j < *matrixColSize; j++){int temp = matrix[i][j];matrix[i][j] = matrix[j][i];matrix[j][i] = temp;}}// 在将矩阵左右对称转换int left = 0, right = (*matrixColSize) - 1;while (left < right) {for (int i = 0; i < matrixSize; i++) {int temp = matrix[i][left];matrix[i][left] = matrix[i][right];matrix[i][right] = temp;}left++;right--;}
}

4. 矩阵置零

代码实现:

void setZeroes(int **matrix, int matrixSize, int *matrixColSize) {int m = matrixSize;int n = matrixColSize[0];int row[m], col[n];memset(row, 0, sizeof(row));memset(col, 0, sizeof(col));for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (!matrix[i][j]) {row[i] = col[j] = 1;}}}for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (row[i] || col[j]) {matrix[i][j] = 0;}}}
}

1. 有效的括号


代码实现:

bool isValid(char *s) {char stack[10000];int top = -1;while (*s) {if (*s == '(' || *s == '{' || *s == '[') {stack[++top] = *s;} else {if (top == -1) { // 栈空return false;}char top_val = stack[top]; // 获取栈顶元素if (top_val == '(' && *s != ')' || top_val == '[' && *s != ']' || top_val == '{' && *s != '}') {return false;} else {top--;}}s++;}if (top != -1) {return false;}return true;
}

2. 二叉树的中序遍历


代码实现:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
/*** Note: The returned array must be malloced, assume caller calls free().*/#define MAX_NODE 100// 递归
// void mid_order1(struct TreeNode *root, int *res, int *returnSize) {
//     if (root == NULL) { // 终止条件
//         return;
//     }
//     mid_order1(root->left, res, returnSize);
//     res[(*returnSize)++] = root->val;
//     mid_order1(root->right, res, returnSize);
// }// 迭代(非递归) 深度优先搜索---借用栈
void mid_order2(struct TreeNode *root, int *res, int *returnSize) {if (root == NULL) {return ;}struct TreeNode *stack[MAX_NODE]; // 定义一个栈int top = -1; // 栈顶struct TreeNode *p = root;struct TreeNode *q = NULL;while (p || top != -1) {if (p) {stack[++top] = p;p = p->left;} else {q = stack[top];res[(*returnSize)++] = q->val;top--;p = q->right;}}
}int* inorderTraversal(struct TreeNode *root, int *returnSize) {int *res = malloc(sizeof(int) * MAX_NODE);*returnSize = 0;// mid_order1(root, res, returnSize);mid_order2(root, res, returnSize);return res;
}

3. 移掉K位数字

代码实现:

思路:贪心 + 单调栈

char* removeKdigits(char *num, int k) {int n = strlen(num), top = -1;char *stack = malloc(sizeof(char) * n);for (int i = 0; i < n; i++) {while (top > -1 && stack[top] > num[i] && k) {top--;k--;}stack[++top] = num[i];}top -= k;char *ans = malloc(sizeof(char) * (n + 1));int ansSize = 0;bool flag = true;for (int i = 0; i <= top; i++) {if (flag && stack[i] == '0') {continue;}flag = false;ans[ansSize++] = stack[i];}if (ansSize == 0) {ans[0] = '0';ans[1] = 0;} else {ans[ansSize] = 0;}return ans;
}

4. 去除重复字母

代码实现:

char* removeDuplicateLetters(char *s) {int hash[26] = {0};int vis[26] = {0};int n = strlen(s);for (int i = 0; i < n; i++) {hash[s[i] - 'a']++;}char *stack = malloc(sizeof(char) * (n + 1));int top = -1;for (int i = 0; i < n; i++) {if (!vis[s[i] - 'a']) {while (top > -1 && stack[top] > s[i]) {if (hash[stack[top] - 'a'] > 0) {vis[stack[top--] - 'a'] = 0;} else {break;}}vis[s[i] - 'a'] = 1;stack[++top] = s[i];}hash[s[i] - 'a'] -= 1;}stack[++top] = '\0';return stack;
}

😭5. 拼接最大数

代码实现:

数论

1. 计数质数

代码实现:

方法一:暴力—超时
bool isPrime(int x) {for (int i = 2; i * i <= x; i++) {if (x % i == 0) {return false;}}return true;
}int countPrimes(int n) {int ans = 0;for (int i = 2; i < n; ++i) {ans += isPrime(i);}return ans;
}
方法二:埃氏筛
如果 x 是质数,那么 x 的倍数:2x, 3x,…一定不是质数
int countPrimes(int n) {if (n < 2) {return 0;}int isPrime[n];memset(isPrime, 1, sizeof(isPrime));int ans = 0;for (int i = 2; i < n; i++) {if (isPrime[i]) {ans += 1;for (int j = i + i; j < n; j += i) {isPrime[j] = 0;}}}return ans;
}

2. n的第K个因子

代码实现:

int kthFactor(int n, int k){int i, j = 0;int count = 0;for(i = 1; i <= n; i++){if (n % i == 0){count++;if (count == k) {return i;}}}return -1;
}

3. 找出数组的做大公约数

代码实现:

int findGCD(int *nums, int numsSize) {int i;int min = INT_MAX, max = INT_MIN;// 找到最大值和最小值for (i = 0; i < numsSize; i++) {if (nums[i] > max) {max = nums[i];}if (nums[i] < min) {min = nums[i];}}for (i = min; i > 0; i--) {if (max % i == 0 && min % i == 0) { return i;}}return 1;
}

4. 生成乘积数组的方案数

代码实现:

方法一:回溯—超时

/*** Note: The returned array must be malloced, assume caller calls free().*/int path[10000];
int pathSize;void dfs(int k, int num, int sum, int *count) {if (sum > num) {return;}if (pathSize == k) {if (sum == num) {(*count)++;*count %= 1000000007;}return;}for (int i = 1; i <= num; i++) {path[pathSize++] = i;dfs(k, num, sum * i, count);pathSize--;}
}int* waysToFillArray(int **queries, int queriesSize, int *queriesColSize, int *returnSize){int *res = malloc(sizeof(int) * queriesSize);for (int i = 0; i < queriesSize; i++) {pathSize = 0;int count = 0;dfs(queries[i][0], queries[i][1], 1, &count);res[i] = count;}*returnSize = queriesSize;return res;
}

5. 按公因数计算最大组件大小


代码实现:

思路:森林与并查集

这篇关于力扣—2024 春招冲刺百题计划的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/890950

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

2024/9/8 c++ smart

1.通过自己编写的class来实现unique_ptr指针的功能 #include <iostream> using namespace std; template<class T> class unique_ptr { public:         //无参构造函数         unique_ptr();         //有参构造函数         unique_ptr(

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已

轻松录制每一刻:探索2024年免费高清录屏应用

你不会还在用一些社交工具来录屏吧?现在的市面上有不少免费录屏的软件了。别看如软件是免费的,它的功能比起社交工具的录屏功能来说全面的多。这次我就分享几款我用过的录屏工具。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  这个软件的操作方式非常简单,打开软件之后从界面设计就能看出来这个软件操作的便捷性。界面的设计简单明了基本一打眼你就会轻松驾驭啦