当前位置: 首页 > wzjs >正文

杭州蚂蚁 做网站的公司搜索引擎优化好做吗

杭州蚂蚁 做网站的公司,搜索引擎优化好做吗,免费素材网站素材库,wordpress 推荐插件福尔摩斯从 X 星收到一份资料,全部是小写字母组成。 他的助手提供了另一份资料:许多长度为 8 的密码列表。 福尔摩斯发现,这些密码是被打乱后隐藏在先前那份资料中的。 请你编写一个程序,从第一份资料中搜索可能隐藏密码的位置…

福尔摩斯从 X 星收到一份资料,全部是小写字母组成。

他的助手提供了另一份资料:许多长度为 8 的密码列表。

福尔摩斯发现,这些密码是被打乱后隐藏在先前那份资料中的。

请你编写一个程序,从第一份资料中搜索可能隐藏密码的位置。

要考虑密码的所有排列可能性。

输入格式

第一行:一个字符串 s,全部由小写字母组成。

紧接着一行是一个整数 n,表示以下有 n 行密码。

紧接着是 n 行字符串,都是小写字母组成,长度都为 8。

输出格式

一个整数,表示每行密码的所有排列在 s 中匹配次数的总和。

数据范围

字符串 s 的长度不超过 220,
1≤n≤1000

输入样例:
aaaabbbbaabbcccc
2
aaaabbbb
abcabccc
输出样例:
4
样例解释

第一个密码匹配了 3 次,第二个密码匹配了 1 次,一共 4 次。

题解:

        最早开始的思想是前缀和,用一个二维向量记录st中每一位之前的字母数量情况,再与那1000个密码进行比较,效率O(N2).

        后面TLE了,于是换了移动窗口的思想,但是还是TLE了。

        最后使用了sort和map,用map记录顺序情况的个数,然后遍历st,使用substr进行切割,然后排序,最后ans+=map[t]即可。时间O(N*Log2N)。

代码:

AC代码:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<iomanip>
#include<queue>
#include<stack>
#include<vector>
#include<unordered_set>
#include<unordered_map>
#include<map>
#include<set>
using namespace std;
typedef long long int ll;
const int INF=1e16;long long int ans=0;
map<string,int> mp;void solve(){int n;string st;cin >> st;cin >> n;for(int i=0;i<n;i++){string s;cin >> s;sort(s.begin(),s.end());mp[s]++;}for(int i=0;i<=st.size()-8;i++){string a=st.substr(i,8);sort(a.begin(),a.end());ans+=mp[a];}cout << ans << "\n";
}int main(){solve();
}

TLE代码:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<iomanip>
#include<queue>
#include<stack>
#include<vector>
#include<unordered_set>
#include<unordered_map>
#include<map>
#include<set>
using namespace std;
typedef long long int ll;
const int INF=1e16;vector<vector<int>> pre((1<<20)+5,vector<int>(30,0));
vector<vector<int>> m(1001,vector<int>(30,0));
long long int ans=0;void solve(){int n;string st;cin >> st;cin >> n;for(int i=0;i<n;i++){string s;cin >> s;for(int j=0;j<s.size();j++){m[i][s[j]-97]++;}}vector<int> a(30,0);int l=1,r=8,last=0;for(int i=0;i<8;i++){a[st[i]-97]++;}for(int i=0;i<1001;i++){if(m[i]==a){ans++;last++;}}while(r<st.size()){if(st[r]==st[l-1]){ans+=last;}else{a[st[r]-97]++;a[st[l-1]-97]--;last=0;for(int i=0;i<1001;i++){if(m[i]==a){ans++;last++;}}}r++;l++;}cout << ans << "\n";
}int main(){solve();
}

http://www.dtcms.com/wzjs/390854.html

相关文章:

  • 做网站界面用的软件百度下载安装
  • 建一个网站素材哪里来seo网站优化培训找哪些
  • 营销网站建设制作设计做百度推广员赚钱吗
  • 做优化的网站搜索引擎优化方案
  • 石家庄市网站建设培训班广州百度推广电话
  • 武汉光谷做网站的公司微信营销的特点
  • seo推广骗局百度seo排名点击软件
  • 企业做网站设计宁波seo营销
  • 中企动力官做网站怎么样武汉网络推广外包公司
  • 成都网站建设设计长尾词挖掘工具爱站网
  • 百度网站推广费用多少钱在线识别图片百度识图
  • 福州网站建设信息免费培训网站
  • 在哪个网站上找超市做生鲜企业如何进行品牌推广
  • 社区类网站建设厦门seo管理
  • asp网站做视频教程郑州seo课程
  • 商城网站 备案武汉seo优
  • 网站建设项目运作的可行性北京网站维护公司
  • 网站换空间 seo惠州百度seo在哪
  • 深圳营销网站建设公司排名个人模板建站
  • 宣传展示型网站设计免费网站建设模板
  • 做黑彩网站能赚钱吗品牌推广内容
  • 网站设计借鉴其它网站侵权吗广州seo排名收费
  • 著名建筑网站项目推广网站
  • 如何在国税网站做票种核定云南网站建设公司哪家好
  • 企业手机网站建设价位怎么联系百度推广
  • 网站开发的教学网站金华百度推广公司
  • 济宁市住房和城乡建设局网站北京专门做seo
  • 网站怎么搭建百度电话查询
  • 十堰哪里有做网站的软文范例100字
  • 广州网站建设50强名单春哥seo博客