拼点游戏
#include<bits/stdc++.h>
using namespace std;
bool cmp(int,int);
int n;
int c[1100],s[1100];
int main()
{
system("color 1");
cin>>n;
for(int i=0;i<n;i++){
cin>>c[i];
}
for(int i=0;i<n;i++){
cin>>s[i];
}
sort(c+0,c+n,cmp);
sort(s+0,s+n,cmp);
int i=0,j=0,cnt=0;
while(i<n&&j>n){
if(s[j]>c[j]){
cnt=cnt+3;
i++;
j++;
}
else if(s[j]==c[i]){
cnt=cnt+2;
i++;
j++;
}
else if(s[j]<c[i]){
i++;
}
}
while(j<n){
cnt=cnt+1;
j++;
}
cout<<n*4-cnt;
return 0;
}
bool cmp(int a,int b){
return a>b;
}
均分纸牌
#include<bits/stdc++.h>
using namespace std;
void f(int);
int n;
int main()
{
system("color 1");
cin>>n;
int a[100],sum=0;
for(int i=0;i<n;i++){
cin>>a[i];
sum=sum+a[i];
}
sum=sum/n;
int cnt=0;
for(int i=0;i<n;i++){
if(a[i]>sum){
a[i+1]=a[i+1]+a[i]-sum;
cnt++;
}
if(a[i]<sum){
a[i+1]=a[i+1]+(sum-a[i]);
cnt++;
}
}
cout<<cnt;
return 0;
}
void f(int n){
return;
}
最大子矩阵
#include<bits/stdc++.h>
using namespace std;
void f(int);
int n;
int main()
{
system("color 1");
cin>>n;
int a[100][100];
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
cin>>a[i][j];
}
}
int m=n,ma=-1;
for(int i=0;i<n;i++){
for(int j=i;j<n;j++){
a[j][i]=a[j-1][i];
}
}
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
ma=max(ma,a[i][j]);
}
}
return 0;
}
void f(int n){
return;
}
整数区间
#include<bits/stdc++.h>
using namespace std;
struct area{
int sp,ep;
};
area a[10010];
void f(int);
bool cmp(area,area);
int n;
int main()
{
system("color 1");
cin>>n;
int cnt=1;
for(int i=0;i<n;i++){
cin>>a[i].sp>>a[i].ep;
}
sort(a+0,a+n,cmp);
int k=a[0].ep;
for(int i=1;i<n;i++){
if(k<a[i].sp){
cnt++;
k=a[i].ep;
}
else if(a[i].ep<k){
k=a[i].ep;
}
}
cout<<cnt;
return 0;
}
void f(int n){
return;
}
bool cmp(area a,area b){
return a.sp<b.sp;
}