关于string的系统函数!
(注:以下函数只可用于string,不适用其他类型的变量)
① a.size();
这个系统函数是用来获取这个string变量的长度的,我们通常会新建一个变量来保存他,以便之后使用。
② sort(a[x],a[y]); (x,y代表一个数字,x是起始点,y是结束点)
这个系统函数是用来对string变量进行排序的(按字典序列),在排列型问题中很实用。
③ reverse(a[x],a[y]);
与前一个系统函数一样,这个也是用来给string变量排序的,只不过是逆序。
④ a.find(b); (a和b代表两个string变量)
这个系统函数是用来查找的,可以在a变量中查找b,如果b存在于a,就是true,反之亦然。
此外,还有4个系统函数我没有公布出来,如果这篇文章点赞超50,并且通过这篇文章关注我的人超过10个,下篇文章我就全部拿出来!
正文开始!
排队打水
#include<bits/stdc++.h>
using namespace std;
int main()
{int n,r;cin>>n>>r;int a[1010]={0};int b[1010]={0};for(int i=0;i<n;i++){cin>>a[i];}sort(a+0,a+n);int sum=a[0];b[0]=a[0];for(int i=1;i<n;i++){if(i<r)b[i]=a[i];else b[i]=b[i-r]+a[i];sum=sum+b[i];}cout<<sum;return 0;
}
活动选择
#include<bits/stdc++.h>
using namespace std;
int main()
{int n;cin>>n;int a[110][110]={0};for(int i=0;i<n;i++){cin>>a[0][i]>>a[1][i];}for(int i=0;i<n-1;i++){for(int j=0;j<n-1-i;j++){if(a[1][j]>a[1][j+1]){swap(a[1][j],a[1][j+1]);swap(a[0][j],a[0][j+1]);}}}int cnt=1;int t=a[1][0];while(true){int cnt2=0;for(int i=0;i<n;i++){if(a[1][i]==t)break;else cnt2++;}bool f=false;int tt;for(int i=cnt2+2;i<n;i++){if(a[0][i]>=a[1][cnt2+1]){f=true;tt=i;break;}}if(f==false){cout<<cnt<<endl;return 0;}else{cnt++;t=a[1][tt];}}return 0;
}
拦截导弹的系统数量求解
#include<bits/stdc++.h>
using namespace std;
int main()
{int n;cin>>n;int a[110]={0};for(int i=0;i<n;i++){cin>>a[i];}int cnt=n;int sum=0;while(cnt!=0){sum++;int max=a[0];for(int i=0;i<n;i++){if(a[i]<=max){max=a[i];for(int j=i;j<n-1;j++){a[j]=a[j+1];}a[n-1]=0;n--;i--;}}cnt=n;}cout<<sum;return 0;
}