博客主页 📖
文章

Count:

计 48 篇
419
六月第四周计划(6.19-6.25)
六月第四周计划(6.19-6.25)
分类: 日记
简介:1# 前言okk恶补上周计划(不愧是我奥)理想计划: 6.19 复习数据结构排序 6.20 计组第三章结束 6.21 计组第四章前俩节 线性代数第一章开始 6.22 计组第四章第三四节 操作系统第一章前两节 线性代数第一章结束 6.23 计组第四章结束 操作系统第一章结束 线性代数第二章1/3 6.24 计组第五章前两节 操作系统第二章1/3 线性代数第二章2/3 6.25 计组第五章第三四节 操作系统第二章2/3 线性代数第二章3/3英语单词 学200 复习300。19实际计划 6.19 计组第三章结束 6.20 计组第四章前俩节 指令的基本概念以及寻址方法 线代1/2 操作系统第一章(操作系统的发展历程)结束 6.21 计组第四章剩余俩节(程序的机器级代码) 操作系统第二章第一节(进程与线程) 6.22 端午放假 6.23 计组第四章后俩节巩固(较难) 操作系统第二章第二节(处理机调度) 6.24 操作系统第二章第三节(同步与互斥) 6.25 实训答辩总结本周端午进行放假,周末实训答辩,再加上本周所学内容较难且为重点,未能按期完成任务,下周回家调养,争取在下下周完成计组。
433
wy的leetcode刷题记录_Day69
wy的leetcode刷题记录_Day69
分类: Code
简介:wy的leetcode刷题记录_Day68声明本文章的所有题目信息都来源于leetcode如有侵权请联系我删掉!时间:2023 6 7前言@TOC2611. 老鼠和奶酪2611. 老鼠和奶酪题目介绍有两只老鼠和 n 块不同类型的奶酪,每块奶酪都只能被其中一只老鼠吃掉。下标为 i 处的奶酪被吃掉的得分为:如果第一只老鼠吃掉,则得分为 reward1[i] 。如果第二只老鼠吃掉,则得分为 reward2[i] 。给你一个正整数数组 reward1 ,一个正整数数组 reward2 ,和一个非负整数 k 。请你返回第一只老鼠恰好吃掉 k 块奶酪的情况下,最大得分为多少。示例 1:输入:reward1 = [1,1,3,4], reward2 = [4,4,1,1], k = 2 输出:15解释:这个例子中,第一只老鼠吃掉第 2 和 3 块奶酪(下标从 0 开始),第二只老鼠吃掉第 0 和 1 块奶酪。 总得分为 4 + 4 +3 + 4 = 15 。 15 是最高得分。 示例 2:输入:reward1 = [1,1], reward2 = [1,1], k = 2 输出:2 解释:这个例子中,第一只老鼠吃掉第 0 和1 块奶酪(下标从 0 开始),第二只老鼠不吃任何奶酪。 总得分为 1 + 1 = 2 。 2 是最高得分。思路简单的贪心+模拟:新建立一个数组reward3用来记录reward1和reward2的差,我们假设老鼠2吃完了所有的奶酪,但是此时要求老鼠1也需要吃k个并得分最大,这时我们将reward3对应的加入reward2就是reward1中的值,那么我们只需要将reward3中最大的k个加入reward2中即可。代码class Solution { public: int miceAndCheese(vector<int>& reward1, vector<int>& reward2, int k) { int n=reward1.size(); vector<int> reward3(n); int ans=0; for(int i=0;i<n;i++) { ans+=reward2[i]; reward3[i]=reward1[i] reward2[i]; } sort(reward3.begin(),reward3.end(),greater<int>()); for(int i=0;i<k;i++) { ans+=reward3[i]; } return ans; } };收获简单的贪心+模拟
396
折半查找(二分查找)
折半查找(二分查找)
分类: Code
简介:考研时需要学习的一个算法,这里手打实现一个简单的折半查找折半查找(二分查找)介绍折半查找法是效率较高的一种查找方法。假设有已经按照从小到大的顺序排列好的五个整数a0~a4,要查找的数是X,其基本思想是: 设查找数据的范围下限为l=0,上限为h=4,求中点m=(l+h)/2,用X与中点元素am比较,若X等于am,即找到,停止查找;否则,若X大于am,替换下限l=m+1,到下半段继续查找;若X小于am,换上限h=m 1,到上半段继续查找;如此重复前面的过程直到找到或者l>h为止。如果l>h,说明没有此数,打印找不到信息,程序结束。 。实现递归#include<iostream> #include<vector> #include<algorithm> using namespace std; int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; //vector<int> array; int BineraySearch(int* a,int left,int right,int target)//返回所在下标 { if(left>right) return 1; int mid = (right left) / 2 + left; cout<<left<<" "<<mid<<" "<<right<<endl; if(a[mid]<target) { left = mid + 1; } else if(a[mid]>target) { right = mid 1; } else { return mid; } BineraySearch(a,left,right,target); } int main() { int target=0; cin >> target; cout<<BineraySearch(a,1,10,target); return 0; } 非递归#include<iostream> #include<vector> #include<algorithm> using namespace std; int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; int main() { int target=0; cin >> target; // cout<<BineraySearch(a,1,10,target); int left=0; int right=9; while(left<=right) { int mid = (right left) / 2 + left; cout<<left<<" "<<mid<<" "<<right<<endl; if(a[mid]<target) { left = mid + 1; } else if(a[mid]>target) { right = mid 1; } else { cout<<mid<<endl; break; } } if(left>right) cout<<"Failed"!<<endl; return 0; }
418
wy的leetcode刷题记录_Day68
wy的leetcode刷题记录_Day68
分类: Code
简介:wy的leetcode刷题记录_Day68声明本文章的所有题目信息都来源于leetcode如有侵权请联系我删掉!时间:2023 6 6前言@TOC1019. 链表中的下一个更大节点2352. 相等行列对题目介绍给你一个下标从 0 开始、大小为 n x n 的整数矩阵 grid ,返回满足 Ri 行和 Cj 列相等的行列对 (Ri, Cj) 的数目。如果行和列以相同的顺序包含相同的元素(即相等的数组),则认为二者是相等的。示例 1:输入:grid = [[3,2,1],[1,7,6],[2,7,7]] 输出:1 解释:存在一对相等行列对:(第 2 行,第 1 列):[2,7,7]示例 2:输入:grid = [[3,1,2,2],[1,4,4,5],[2,4,2,2],[2,4,2,2]] 输出:3 解释:存在三对相等行列对:(第 0 行,第 0 列):[3,1,2,2](第 2 行, 第 2 列):[2,4,2,2](第 3 行, 第 2 列):[2,4,2,2]思路1.暴力解法:提出每一行的元素与每一列的元素进行比对。(简易优化思路:空间换时间,建立2n个序列,分别保留每行和每列的元素,再进行比较)2.哈希表(上面解法的建议优化思路):首先将矩阵的行放入哈希表中统计次数,哈希表的键可以是将行拼接后的字符串,也可以用各语言内置的数据结构,然后分别统计每一列相等的行有多少,求和即可。代码class Solution { public: int equalPairs(vector<vector<int>>& grid) { int n = grid.size(); map<vector<int>, int> cnt; for (auto row : grid) { cnt[row]++; } int res = 0; for (int j = 0; j < n; j++) { vector<int> arr; for (int i = 0; i < n; i++) { arr.emplace_back(grid[i][j]); } if (cnt.find(arr) != cnt.end()) { res += cnt[arr]; } } return res; } }; 收获简单的模拟题
454
wy的leetcode刷题记录_Day61
wy的leetcode刷题记录_Day61
分类: Code
简介:wy的leetcode刷题记录_Day61声明本文章的所有题目信息都来源于leetcode如有侵权请联系我删掉!时间:2022 12 26前言@TOC1759. 统计同构子字符串的数目今天的每日一题是:1759. 统计同构子字符串的数目题目介绍给你一个字符串 s ,返回 s 中 同构子字符串 的数目。由于答案可能很大,只需返回对 109 + 7 取余 后的结果。同构字符串 的定义为:如果一个字符串中的所有字符都相同,那么该字符串就是同构字符串。子字符串 是字符串中的一个连续字符序列。示例 1: 输入:s = "abbcccaa" 输出:13 解释:同构子字符串如下所列: "a" 出现 3 次。 "aa" 出现 1次。 "b" 出现 2 次。 "bb" 出现 1 次。 "c" 出现 3 次。 "cc" 出现 2 次。 "ccc" 出现 1次。 3 + 1 + 2 + 1 + 3 + 2 + 1 = 13示例 2: 输入:s = "xy" 输出:2 解释:同构子字符串是 "x" 和 "y" 。思路方法一:暴力解法:遍历整个字符串,每一次遍历到不同的字符我们将前面的切除掉,然后计算当前字符串得分,得分规则设当前字符重复n次,得分为递增求和公式temp+temp*(temp 1)/2,超时原因是字符串切割次数过多。(超时)方法二:改进简单模拟:遍历整个字符串,每一次迭代我们不进行字符串的切分,使用一个变量来记录当前对比的字符即可,对于一个字符的重复了n次那么其贡献值为n*(n+1)/2,然后我们再跳到下一个不同的字符,并跟新对比的字符以及出现次数。代码class Solution { public: int countHomogenous(string s) { int n=s.size(); if(n==1) return 1; if(n==0) return 0; int ans=0; for(int i=0;i<n;) { if(i==n) break; int temp=helper(s); if(temp==1) { ans++; i++; } else { ans+=temp+temp*(temp 1)/2; i+=temp; } s=s.substr(temp); } return ans; } int helper(string s) { char Compare=s[0]; int res=1; int n=s.size(); if(n==1) return 1; for(int i=1;i<n;i++) { if(s[i]==Compare) res++; else return res; } return res; } };class Solution { public: int countHomogenous(string s) { long long MOD = 1000000007; int n=s.size(); if(n==1) return 1; if(n==0) return 0; int ans=0; char prev=s[0]; int temp=1; for(int i=1;i<n;i++) { if(i==n) break; //int temp=helper(s); if(prev==s[i]) { temp++; } else{ prev=s[i]; ans+=(temp + 1) * temp / 2; temp=1; } //s=s.substr(temp); } ans+=(long)(long)(temp + 1) * temp / 2%MOD; return ans%MOD; } 收获多观察才能知道自己哪里需要改进
博客主页 wyのblog-我的美好生活记录 I know you are here. 百度统计
鄂ICP备2023003777号-1 本站已运行 1 年 142 天 0 小时 3 分 自豪地使用 Typecho 建站,并搭配 MyDiary 主题 Copyright © 2023 ~ 2025. wyのblog-我的美好生活记录 All rights reserved.
打赏图
打赏博主
欢迎
搜 索
足 迹
分 类
  • 默认分类
  • Code
  • 日记
  • 音乐
  • 游戏
  • 阅读
  • 计划
  • 图片
  • 旅游
  • 影视
  • 文章阅读