模拟的介绍和使用

模拟就是对某一个过程进行简单的演算,通过找到一定的规律,来简化代码,提高时间复杂度等。

class Solution {

public:

string modifyString(string s) {

int n=s.size();

for(int i=0;i<n;i++){

if(s[i]=='?'){

for(char ch='a';ch<='z';ch++){

if((i==0||ch!=s[i-1])&&(i==n-1||ch!=s[i+1])){

s[i]=ch;

break;

}

}

}

}

return s;

}

};

class Solution {

public:

int findPoisonedDuration(vector<int>& timeSeries, int duration) {

int ans = 0;

int expired = 0;

for (int i = 0; i < timeSeries.size(); ++i) {

if (timeSeries[i] >= expired) {

ans += duration;

} else {

ans += timeSeries[i] + duration - expired;

}

expired = timeSeries[i] + duration;

}

return ans;

}

};

class Solution {

public:

string convert(string s, int a) {

if(a==1) return s;

string ret;

int d=2*a-2;

int n=s.size();

for(int i=0;i<n;i+=d){

ret+=s[i];

}

for(int k=1;k<a-1;k++){

for(int i=k,j=d-k;i<n||j<n;i+=d,j+=d){

if(i<n) ret+=s[i];

if(j<n) ret+=s[j];

}

}

for(int i=a-1;i<n;i+=d){

ret+=s[i];

}

return ret;

}

};

class Solution {

public:

string countAndSay(int n) {

string ret="1";

for(int i=1;i<n;i++){

string a;

for(int left=0,right=0;right<ret.size();){

while(right<ret.size()&&ret[left]==ret[right]) right++;

a+=to_string(right-left)+ret[left];

left=right;

}

ret=a;

}

return ret;

}

};

class Solution {

public:

int minNumberOfFrogs(string croakOfFrogs) {

string t="croak";

int n=t.size();

vector<int> hash(n);

unordered_map<char,int> index;

for(int i=0;i<n;i++)

index[t[i]]=i;

for(auto ch: croakOfFrogs){

if(ch=='c'){

if(hash[n-1]!=0) hash[n-1]--;

hash[0]++;

}else{

int i=index[ch];

if(hash[i-1]==0) return -1;

hash[i-1]--;

hash[i]++;

}

}

for(int i=0;i<n-1;i++){

if(hash[i]!=0) return -1;

}

return hash[n-1];

}

};

期待下次交流!!!

相关推荐
ss2736 分钟前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手26 分钟前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记40 分钟前
逻辑回归与Softmax回归
算法·回归·逻辑回归
try2find1 小时前
打印ascii码报错问题
java·linux·前端
014-code1 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
Nicander1 小时前
多数据源下@transcation事务踩坑
java·后端
郑州光合科技余经理1 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
それども2 小时前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
南子北游2 小时前
Python学习(基础语法1)
开发语言·python·学习
张健11564096482 小时前
使用信号量限制并发数量
开发语言·c++