模拟题
data:image/s3,"s3://crabby-images/5eb0e/5eb0ecef612c56905141387af955fc228c328d3f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e1bd8/e1bd8b6197caa6c8b094081323b44ccc1357264d" alt="在这里插入图片描述"
class Solution {
public:
int findNthDigit(int n) {
long long k=1,c=9,s=1;
while(n>k*c){
n-=k*c;
k++,c*=10,s*=10;
}
s+=(n+k-1)/k-1;
n=n%k?n%k:k;
return to_string(s)[n-1]-'0';
}
};
floyd
data:image/s3,"s3://crabby-images/599c6/599c613c637c6373d3ebe7d836fb6048ad931c5f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c7378/c7378566bf2cccb0752bcc2c1bc00c12dd197fc4" alt="在这里插入图片描述"
class Solution {
public:
vector<double> calcEquation(vector<vector<string>>& e, vector<double>& v, vector<vector<string>>& q) {
unordered_set<string> vers;
unordered_map<string,unordered_map<string,double>> d;
for(auto i=0;i<e.size();i++){
auto a=e[i][0],b=e[i][1];
auto c=v[i];
d[a][b]=c,d[b][a]=1/c;
vers.insert(a),vers.insert(b);
}
for(auto& k:vers)
for(auto& i:vers)
for(auto& j:vers){
if(d[i][k]&&d[j][k]){
d[i][j]=d[i][k]*d[k][j];
}
}
vector<double> res;
for(auto& c:q){
auto a=c[0],b=c[1];
if(d[a][b]) res.push_back(d[a][b]);
else res.push_back(-1);
}
return res;
}
};
水
data:image/s3,"s3://crabby-images/784ad/784ad8c8613c6a683a0ce29c945bf981319d72f7" alt="在这里插入图片描述"
class Solution {
public:
unordered_map<int,vector<int>> hash;
Solution(vector<int>& nums) {
for(auto i=0;i<nums.size();i++){
hash[nums[i]].push_back(i);
}
}
int pick(int target) {
return hash[target][rand()%hash[target].size()];
}
};
水
data:image/s3,"s3://crabby-images/017d3/017d35fca17f5584beb71d620931b8ba94b3fb98" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/3333e/3333e57494612955c3866a2132abd6164c165ee4" alt="在这里插入图片描述"
class Solution {
public:
map<long long,int> dp;
int integerReplacement(int n) {
return f(n);
}
long long f(long long n){
if(dp[n]) return dp[n];
if(n==1) return 0;
if(n%2==0) return dp[n]=f(n/2)+1;
return dp[n]=min(f(n+1),f(n-1))+1;
}
};
水,sb题
data:image/s3,"s3://crabby-images/b35b2/b35b2db41a62f9cd20efc1c5f41a08d1e097641d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2979e/2979ed190b5b6b53299ec88ab20d49f7f982842f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/7a44f/7a44fb9f6129df2537ce35213405c0781ac45244" alt="在这里插入图片描述"
class Solution {
public:
int maxRotateFunction(vector<int>& nums) {
typedef long long LL;
LL sum=0,cur=0;
for(auto c:nums) sum+=c;
int n=nums.size();
for(int i=0;i<nums.size();i++) cur+=i*nums[i];
LL res=cur;
for(int i=n-1;i>=0;i--){
cur+=sum-(LL)n*nums[i];
res=max(res,cur);
}
return res;
}
};
双指针
data:image/s3,"s3://crabby-images/dc9b4/dc9b4350aaa2f5983375d322452457261eab53ad" alt="在这里插入图片描述"
class Solution {
public:
int K;
unordered_map<char,int> cnt;
void add(char c,int& x,int& y){
if(!cnt[c]) x++;
cnt[c]++;
if(cnt[c]==K) y++;
}
void del(char c,int& x,int& y){
if(cnt[c]==K) y--;
cnt[c]--;
if(!cnt[c]) x--;
}
int longestSubstring(string s, int _K) {
K=_K;
int res=0;
for(int k=1;k<=26;k++){
cnt.clear();
for(int i=0,j=0,x=0,y=0;i<s.size();i++){
add(s[i],x,y);
while(x>k) del(s[j++],x,y);
if(x==y) res=max(res,i-j+1);
}
}
return res;
}
};
dfs
data:image/s3,"s3://crabby-images/07eb7/07eb7f78e117ca5d2f68e27ce31f6df93b7631dd" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/959ce/959ceaf7119ce1b9ab770c037c428c33763ceb44" alt="在这里插入图片描述"
class Solution {
public:
string decodeString(string s) {
int u=0;
return dfs(s,u);
}
string dfs(string s,int& u){
string res;
while(u<s.size()&&s[u]!=']'){
if(s[u]>='a'&&s[u]<='z'||s[u]>='A'&&s[u]<='Z') res+=s[u++];
else if(s[u]>='0'&&s[u]<='9'){
int k=u;
while(s[k]>='0'&&s[k]<='9') k++;
auto x=stoi(s.substr(u,k-u));
u=k+1;
auto y=dfs(s,u);
u++;
while(x--) res+=y;
}
}
return res;
}
};
模拟
data:image/s3,"s3://crabby-images/1ce73/1ce737d2ba5fd3b00ec02e0979c038c181b9c314" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/6ce08/6ce08104b1bb7b509a4f65af8c71bebabdddd4f5" alt="在这里插入图片描述"
class Solution {
public:
int get(int x,int y){
return x>>y&1;
}
bool validUtf8(vector<int>& data) {
for(int i=0;i<data.size();i++){
if(!get(data[i],7)) continue;
int k=0;
while(k<=4&&get(data[i],7-k)) k++;
if(k>4||k==1) return false;
for(int j=0;j<k-1;j++){
int t=i+j+1;
if(t>=data.size()) return false;
if(!(get(data[t],7)&&!get(data[t],6))) return false;
}
i+=k-1;
}
return true;
}
};
水题
data:image/s3,"s3://crabby-images/b36f8/b36f82fa92c4810fbd12861b8b2800bfc17d1be5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/cacf4/cacf4f4bb07b73c2d7860971599c2388ef0d88e6" alt="在这里插入图片描述"
class Solution {
public:
bool isSubsequence(string s, string t) {
int k=0;
for(auto c:t){
if(k<s.size()&&c==s[k])
k++;
}
return k==s.size();
}
};
模拟题白给
data:image/s3,"s3://crabby-images/6a724/6a72461bd2655f564c89a0e91981bd12d0863b6b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/a706a/a706a137edc2716ab2e3f19b5aad2c8cfebe207f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/cb4f6/cb4f64161d8c0eeb2c9ab02e76155be0290d8bef" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f7099/f709971e4b5e1bd98942ad20106a9b718b623235" alt="在这里插入图片描述"
class Solution {
public:
int lastRemaining(int n) {
if(n==1) return 1;
return 2*(n/2+1-lastRemaining(n/2));
}
};
|