文章目录
- [A. 国际旅行Ⅰ](#A. 国际旅行Ⅰ)
- D.A*BBBB
- F.水灵灵的小学弟
- H.狼狼的备忘录
- I.重生之zbk要拿回属于他的一切
- J.这是签到
链接
A. 国际旅行Ⅰ
题意与思路
这是一个签到题,输入的城市的值排序,然后按他给的顺序输出就行了
代码
cpp
#include <bits/stdc++.h>
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
using namespace std;
int a[1010];
signed main()
{
IOS
int T=1;
//cin>>T;
while(T--)
{
int n,m,q,c,b,d;
cin>>n>>m>>q;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
sort(a+1,a+1+n);
for(int i=1;i<=m;i++)
cin>>c>>d;
while(q--)
{
cin>>b;
cout<<a[b]<<endl;
}
}
return 0;
}
D.A*BBBB
题意与思路
这个题就是两个大数相乘,我么们可以找一下规律看下图
因为b的每一位都相同上图是第一个样例乘2得到的,可以看出中间的数值是一样的所以,就可以把这看成一种规律来写
代码
cpp
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2e6+10;
void solve()
{
string a,b;
cin>>a;
cin>>b;
//cout<<a<<' '<<b<<endl;
if(a.length()==1&&a[0]-'0'==0)
{
cout<<0<<endl;
return;
}
ll c[N],ans[N];
memset(c,0,sizeof c);
memset(ans,0,sizeof ans);
ll lc=0;
for(ll i=a.length()-1;i>=0;i--)
{
c[a.length()-i-1]=a[i]-'0';
lc++;
//d[a.length()-i-1]=a[i];
}
ll bb=b[0]-'0';
if(bb==0)
{
cout<<0<<endl;
return;
}
ll t=0;
//c[strlen(c)]='0';
for(ll i=0;i<lc;i++)
{
ll s=c[i]*bb+t;
c[i]=s%10;
t=s/10;
}
if(t!=0)
{
c[lc]=t;
lc++;
}
for(ll i=1;i<lc;i++) c[i]+=c[i-1];
ll cc=0,tt=0;
for(ll i=0;i<lc+b.length();i++)
{
if(i<lc) ans[i]=c[i];
else ans[i]=c[lc-1];
if(i>=b.length()) ans[i]-=c[i-b.length()];
}
//for(int i=0;i<lc+b.length();i++) cout<<ans[i]<<' ';
//cout<<endl;
//t=0;
ll lans=0;
t=0;
for(ll i=0;i<lc+b.length();i++)
{
//if(t==0&&ans[i]==0) break;
t+=ans[i];
ans[i]=t%10;
//ans[i+1]+=t/10;
t/=10;
lans++;
}
while(t!=0)
{
ans[lans++]=t%10;
t/=10;
}
ll f=0;
for(ll i=lans;i>=0;i--)
{
if(f==0&&ans[i]==0) continue;
else if(f==0&&ans[i]!=0)
{
f=1;
}
cout<<ans[i];
} //cout<<ans[i]<<' ';
cout<<endl;
}
int main()
{
int t;
cin>>t;
while(t--) solve();
}
F.水灵灵的小学弟
题意与思路
这个题目意思是个博弈题,但博弈是一点没考,他说谁赢输出谁的名字首拼大写,但题目上两个名字首拼相同,所以不管输入什么,都输出首拼就行
代码
cpp
#include <bits/stdc++.h>
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
using namespace std;
int a[1010];
signed main()
{
IOS
int T=1;
cin>>T;
while(T--)
{
int a,b;
cin>>a>>b;
cout<<"DHY"<<endl;
}
return 0;
}
H.狼狼的备忘录
题意与思路
这个题就是,给你几行信息每行有名字和信息,让名字相同的合并在一起,但如果一个人有两个信息,一个信息是另一个的后缀就不用保留后缀的那个信息了,如果信息相等就随便舍去一个,我的思路就是把信息都存在一个map嵌套set容器中,然后把相同人的信息存到一个set里面,让后用rfind函数去找是否有后缀,如果有就删除,反之就添加到set里
代码
cpp
#include <bits/stdc++.h>
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
using namespace std;
map<string,set<string>>ma;
signed main()
{
IOS
int T=1;
cin>>T;
while(T--)
{
string s,a;
int n;
cin>>s>>n;
while(n--)
{
int f=0;
cin>>a;
if(ma[s].size()==0)
ma[s].insert(a);
else
{
vector<string>v;
for(auto i:ma[s])
{
if(i.size()>=a.size())
{
if(i.rfind(a)!=-1&&i.rfind(a)+a.size()==i.size())
f=1;
}
else
{
if(a.rfind(i)!=-1&&a.rfind(i)+i.size()==a.size())
v.push_back(i);
}
}
if(f==0)
ma[s].insert(a);
if(v.size())
{
ma[s].insert(a);
for(auto x:v)
{
ma[s].erase(x);
}
}
}
}
}
cout<<ma.size()<<endl;
for(auto x:ma)
{
cout<<x.first<<" "<<ma[x.first].size()<<" ";
for(auto y:ma[x.first])
{
cout<<y<<" ";
}
cout<<endl;
}
return 0;
}
I.重生之zbk要拿回属于他的一切
题意与思路
这个题目就是给你一个字符串让你求他有几个"chuan"字 串,我们可以每次截取5个字符判断是否与"chuan"
代码
cpp
#include <bits/stdc++.h>
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
using namespace std;
signed main()
{
IOS
int T=1;
//cin>>T;
while(T--)
{
string s,b="chuan";
int n,sum=0;
cin>>n>>s;
for(int i=0;i<s.size();i++)
{
string a=s.substr(i,5);
if(b==a)
sum++;
}
cout<<sum<<endl;
}
return 0;
}
J.这是签到
题意与思路
这个题就是给你n行m列的矩形,求(1,1)到(n,n)的行列式,如果给你(3,4)就把第四行全部补0,列不够也是如此
我的思路就是纯暴力,因为范围最大就是5,所以把1到5的行列式全列出来就行了
代码
cpp
#include <bits/stdc++.h>
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
using namespace std;
int a[10][10];
signed main()
{
IOS
int T=1;
//cin>>T;
while(T--)
{
int m,n,mi=1e9,t;
cin>>m>>n;
int k=max(m,n);
for(int i=1;i<=m;i++)
{
for(int j=1;j<=n;j++)
{
cin>>a[i][j];
}
}
mi=min(mi,a[1][1]);
if(k==1)
{
cout<<mi<<endl;
return 0;
}
mi=min(mi,a[1][1]*a[2][2]-a[1][2]*a[2][1]);
if(k==2)
{
cout<<mi<<endl;
return 0;
}
t=a[1][1]*a[2][2]*a[3][3]+
a[1][2]*a[2][3]*a[3][1]+
a[1][3]*a[2][1]*a[3][2]-
a[1][3]*a[2][2]*a[3][1]-
a[2][3]*a[3][2]*a[1][1]-
a[3][3]*a[1][2]*a[2][1];
mi=min(mi,t);
if(k==3)
{
cout<<mi<<endl;
return 0;
}
t=a[1][1]*a[2][2]*a[3][3]*a[4][4]+
a[1][2]*a[2][3]*a[3][4]*a[4][1]+
a[1][3]*a[2][4]*a[3][1]*a[4][2]+
a[1][4]*a[2][1]*a[3][2]*a[4][3]-
a[1][4]*a[2][3]*a[3][2]*a[4][1]-
a[2][4]*a[3][3]*a[4][2]*a[1][1]-
a[3][4]*a[4][3]*a[1][2]*a[2][1]-
a[4][4]*a[1][3]*a[2][2]*a[3][1];
mi=min(mi,t);
if(k==4)
{
cout<<mi<<endl;
return 0;
}
t=a[1][1]*a[2][2]*a[3][3]*a[4][4]*a[5][5]+
a[1][2]*a[2][3]*a[3][4]*a[4][5]*a[5][1]+
a[1][3]*a[2][4]*a[3][5]*a[4][1]*a[5][2]+
a[1][4]*a[2][5]*a[3][1]*a[4][2]*a[5][3]+
a[1][5]*a[2][1]*a[3][2]*a[4][3]*a[5][4]-
a[1][5]*a[2][4]*a[3][3]*a[4][2]*a[5][1]-
a[2][5]*a[3][4]*a[4][3]*a[5][2]*a[1][1]-
a[3][5]*a[4][4]*a[5][3]*a[1][2]*a[2][1]-
a[4][5]*a[5][4]*a[2][2]*a[1][3]*a[3][1]-
a[1][4]*a[4][1]*a[2][3]*a[3][2]*a[5][5];
mi=min(mi,t);
cout<<mi<<endl;
}
return 0;
}
总结
这一次比赛中间的题都是大模拟,用stl容器比较多,而我stl用的不好导致模拟题没写出来,当时连两个容器一起怎么遍历都不知道,别说写了,赛后我要好好学一下容器,要不然只用数组对于一些大模拟题太吃亏了