小米算法岗三道题(全AC)
第一道,字符串匹配,利用窗口滑移:
#include<iostream>
#include<map>
using namespace std;
int main(){
string s1,s2;
while(cin>>s1>>s2){
map<char,int> mp1;
map<char,int>mp2;
int len1=s1.length();
int len2=s2.length();
if(len1==0||len2==0) cout<<-1<<" "<<-1<<endl;
for(int i=0;i<len2;i++){
mp1[s2[i]]++;
mp2[s2[i]]++;
}
int l=-1,r=-1;
int i=0;
int count=len2;
int ll=0;
while(i<len1){
if(mp2[s1[i]]>0){
if(mp1[s1[i]]>0){
count--;
}
mp1[s1[i]]--;
}
if(count==0){
while(mp2[s1[ll]]==0||mp1[s1[ll]]<0){
if(mp1[s1[ll]]<0) mp1[s1[ll]]++;
ll++;
}
// cout<<ll<<" "<<i<<endl;
if((l==-1&&r==-1)||r-l+1>i-ll+1){
int s=0;
for(int j=ll;j<=i;j++){
if(s1[j]==s2[s]) s++;
}
if(s==len2) {
l=ll;
r=i;
}
}
}
i++;
}
cout<<l<<" "<<r<<endl;
}
}
第二道 大数阶乘,HDUOJ上的原题
#include<map>
using namespace std;
int main(){
string s1,s2;
while(cin>>s1>>s2){
map<char,int> mp1;
map<char,int>mp2;
int len1=s1.length();
int len2=s2.length();
if(len1==0||len2==0) cout<<-1<<" "<<-1<<endl;
for(int i=0;i<len2;i++){
mp1[s2[i]]++;
mp2[s2[i]]++;
}
int l=-1,r=-1;
int i=0;
int count=len2;
int ll=0;
while(i<len1){
if(mp2[s1[i]]>0){
if(mp1[s1[i]]>0){
count--;
}
mp1[s1[i]]--;
}
if(count==0){
while(mp2[s1[ll]]==0||mp1[s1[ll]]<0){
if(mp1[s1[ll]]<0) mp1[s1[ll]]++;
ll++;
}
// cout<<ll<<" "<<i<<endl;
if((l==-1&&r==-1)||r-l+1>i-ll+1){
int s=0;
for(int j=ll;j<=i;j++){
if(s1[j]==s2[s]) s++;
}
if(s==len2) {
l=ll;
r=i;
}
}
}
i++;
}
cout<<l<<" "<<r<<endl;
}
}
第二道 大数阶乘,HDUOJ上的原题
#include <iostream>
#include<algorithm>
#include<stdio.h>
using namespace std;
int main()
{ int m,i,j;
while (cin>>m)
{ int flag=1;
int carry=0,diff=0;
int weishu[4000];
weishu[0]=1;
for (i=2;i<=m;i++)
{
for (j=1;j<=flag;j++) {
diff=weishu[j-1]*i+carry;
weishu[j-1]=diff%10;
carry=diff/10;
// cout<<diff<<" "<<carry<<endl;
}
while (carry)
{
flag++;
weishu[flag-1]=carry%10;
carry/=10;
}
}
for (i=flag-1;i>=0;i--)
{ cout<<weishu[i];
if(i==0) cout<<endl;
}
}
return 0;
}
第三道题,其实就是,一看就懂,哈哈
#include<algorithm>
#include<stdio.h>
using namespace std;
int main()
{ int m,i,j;
while (cin>>m)
{ int flag=1;
int carry=0,diff=0;
int weishu[4000];
weishu[0]=1;
for (i=2;i<=m;i++)
{
for (j=1;j<=flag;j++) {
diff=weishu[j-1]*i+carry;
weishu[j-1]=diff%10;
carry=diff/10;
// cout<<diff<<" "<<carry<<endl;
}
while (carry)
{
flag++;
weishu[flag-1]=carry%10;
carry/=10;
}
}
for (i=flag-1;i>=0;i--)
{ cout<<weishu[i];
if(i==0) cout<<endl;
}
}
return 0;
}
第三道题,其实就是,一看就懂,哈哈
#include<iostream>
using namespace std;
int main(){
int n;
int d[10000];
d[0]=1;
d[1]=1;
for(int i=2;i<10000;i++){
d[i]=d[i-1]+d[i-2];
}
while(cin>>n){
cout<<d[n]<<endl;
}
}
#小米#using namespace std;
int main(){
int n;
int d[10000];
d[0]=1;
d[1]=1;
for(int i=2;i<10000;i++){
d[i]=d[i-1]+d[i-2];
}
while(cin>>n){
cout<<d[n]<<endl;
}
}