一些HDOJ上水题的代码(无题目索引:Practice9,10,拓展1,2)

阅读 55

2023-02-08


Practice9

1001

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
LL n;
while(cin>>n){
LL sum = 0;
for(int i = 1; i <= n; i++){
sum += i;
}
cout<<sum<<"\n\n";
}
return 0;
}

1002

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
int d[10] = {1,1,4,4,2,1,1,4,4,2};
int f[10][4]={{0},{1},{6,2,4,8},{1,3,9,7},{6,4},{5},{6},{1,7,9,3},{6,8,4,2},{1,9}};
int main(){
int T; cin>>T;
while(T--){
int n; cin>>n;
cout<<f[n%10][n%d[n%10]]<<"\n";//f[a%10][b%d[a%10]]
}
return 0;
}

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL pows(LL a, LL b){
if(b==0)return 1;
LL res = pows(a,b/2)%10;
if(b%2==1)return res*res%10*a;
else return res*res%10;
}
int main(){
LL T; cin>>T;
while(T--){
LL n; cin>>n;
cout<<pows(n,n)%10<<"\n";
}
return 0;
}

1003

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
int f[1000010];
int main(){
f[0] = 7%3; f[1] = 11%3;
for(int i = 2; i <= 1000010; i++)
f[i] = (f[i-1]+f[i-2])%3;
int n;
while(cin>>n){
if(f[n]==0)cout<<"yes\n";
else cout<<"no\n";
}
return 0;
}

1004

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL pows(LL a, LL b){
if(b==0)return 1;
LL res = pows(a,b/2)%1000;
if(b%2==1)return res*res%1000*a;
else return res*res%1000;
}
int main(){
LL a, b;
while(cin>>a>>b){
if(a==0 && b==0)break;
cout<<pows(a,b)%1000<<"\n";
}
return 0;
}

1005

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL pows(LL a, LL b){
if(b==0)return 1;
LL res = pows(a,b/2)%1000;
if(b%2==1)return res*res%1000*a;
else return res*res%1000;
}
double f(double x){
return 8*pow(x,4)+7*pow(x,3)+2*pow(x,2)+3*x+6;
}
int main(){
int T; cin>>T;
while(T--){
int y; cin>>y;
if(y<f(0)||y>f(100)){
cout<<"No solution!"<<endl;
continue;
}
double l = 0, r = 100, x=0;
while(r-l>=1e-10){
x = (l+r)/2;
double yy =f(x);
if(yy<y)l = x;
else r = x;
}
printf("%.4lf\n",x);
}
return 0;
}

1006

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL pows(LL a, LL b){
if(b==0)return 1;
LL res = pows(a,b/2)%1000;
if(b%2==1)return res*res%1000*a;
else return res*res%1000;
}
int f[50];
int main(){
f[1] = f[2] = 1;
for(int i = 3; i <= 50; i++)
f[i] = f[i-1]+f[i-2];
int n; cin>>n;
for(int i = 1; i <= n; i++){
int m; cin>>m;
cout<<f[m]<<"\n";
}
return 0;
}

1007

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL pows(LL a, LL b){
if(b==0)return 1;
LL res = pows(a,b/2)%1000;
if(b%2==1)return res*res%1000*a;
else return res*res%1000;
}
LL f[70];
int main(){
f[0] = f[1] = 1;
for(int i = 2; i <= 70; i++)
f[i] = f[i-1]+f[i-2];
int n; cin>>n;
for(int i = 1; i <= n; i++){
int a, b;
cin>>a>>b;
cout<<f[b-a]<<"\n";
}
return 0;
}

1008

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL pows(LL a, LL b){
if(b==0)return 1;
LL res = pows(a,b/2)%1000;
if(b%2==1)return res*res%1000*a;
else return res*res%1000;
}
LL f[70];
int main(){
f[0] = f[1] = 1;
for(int i = 2; i <= 70; i++)
f[i] = f[i-1]+f[i-2];
int n;
while(cin>>n){
cout<<f[n]<<"\n";
}
return 0;
}

1009

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
//1.增加第n条直线的时候,跟之前的直线最多有n-1个交点,此时分出的部分多出了(n-1)+1;
//2.折线时,已经场上有n-1条折线,相当于2*(n-1)条线,再加入第n条折线,相当于加入2条直线,这样一来产生2*2*(n-1)个新交点,与2*2*(n-1)+1个平面产生接触产生4*(n-1)+1个新平面
LL f[10010];
int main(){
f[1] = 2; f[2] = 7;
for(int i = 3; i <= 10000; i++)
f[i] = f[i-1]+4*(i-1)+1;
int n; cin>>n;
while(n--){
int x; cin>>x;
cout<<f[x]<<"\n";
}
return 0;
}

1010

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL f[10010];
int main(){
f[1] = 1;
f[2] = 3; f[3] = 5;
for(int i = 4; i <= 100; i++)
f[i] = f[i-1]+2*f[i-2];//全部填充1*1或者填2*2和1*1
int n; cin>>n;
while(n--){
int x; cin>>x;
cout<<f[x]<<"\n";
}
return 0;
}

1011

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL f[10010];
int main(){
f[1] = 1; f[2] = 3;
for(int i = 3; i <= 100; i++)
f[i] = f[i-1]+2*f[i-2];
int n; cin>>n;
while(n--){
int x; cin>>x;
cout<<f[x]<<"\n";
}
return 0;
}

1012

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL f[70];
//1.如果第n位为O的情况的话,第n-1位不能为O,也就是E,或者F.那么n-2位就不受限制即为2*f(n-2)
//2. 如果第n位不为O的话,就是E或者F.第n-1位不受限制为2*f(n-1)
int main(){
f[1] = 3; f[2] = 8;
for(int i = 3; i <= 70; i++)
f[i] = (f[i-1]+f[i-2])*2;
int n;
while(cin>>n){
cout<<f[n]<<"\n";
}
return 0;
}

1013

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL f[70];
int main(){
f[1] = 3; f[2] = 6; f[3] = 6;
for(int i = 4; i <= 70; i++)
f[i] = f[i-1]+2*f[i-2];//1.最后一个格子和第一个颜色不同时,因为收尾不能相同,只有一种颜色(即n-1的颜色)。2.颜色相同时,有两种可以选。
int n;
while(cin>>n){
cout<<f[n]<<"\n";
}
return 0;
}

1014

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
string s; int x;
while(cin>>s){
int ok = 1;
for(int i = 0; i < s.size(); i++){
if(!(s[i]>='A'&&s[i]<='F' || s[i]>='a'&&s[i]<='f' || s[i]>='0'&&s[i]<='9'))ok = 0;
}
if(!ok){cout<<"Error!\n";continue;}
stringstream ss;
ss<<std::hex<<s;//oct,dec,hex
ss>>x;
cout<<x<<"\n";
}
return 0;
}

1015

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
string base = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

int main(){
string s; int k;
while(cin>>s>>k){
int ok = 1;
if(k>16||k<2){cout<<"Error!\n";continue;}
for(int i = 0; i < s.size(); i++){
if(!(s[i]>='A'&&s[i]<='F' || s[i]>='a'&&s[i]<='f' || s[i]>='0'&&s[i]<='9'))ok = 0;
if(toupper(s[i])>=base[0+k]){ok = 0;}
}
if(!ok){cout<<"Error!\n";continue;}
int ans = 0;
for(int i = 0; i < s.size(); i++){
ans *= k;
if(isupper(s[i]))ans += s[i]-'A'+10;
else if(islower(s[i]))ans += s[i]-'a'+10;
else ans += s[i]-'0';
}
cout<<ans<<"\n";
}
return 0;
}

1016

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
string base = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

int main(){
int T; cin>>T;
while(T--){
int n, k; cin>>n>>k;
string s;
while(n){
s += base[n%k];
n /= k;
}
reverse(s.begin(),s.end());
cout<<s<<"\n";
}
return 0;
}

Practice 10

1001

//f[i][j]:从(i,j)出发能获得的最大值 _裸DFS
#include<bits/stdc++.h>
using namespace std;
int n, a[110][110], f[110][110];
int dfs(int i, int j){
if(f[i][j])return f[i][j];
if(i>n || j>n)return 0;
return f[i][j] = max(dfs(i+1,j),dfs(i+1,j+1))+a[i][j];
}
int main(){
int T; cin>>T;
while(T--){
cin>>n;
memset(a,0,sizeof(a));
memset(f,0,sizeof(f));
for(int i = 1; i <= n; i++)
for(int j = 1; j <= i; j++)
cin>>a[i][j];
cout<<dfs(1,1)<<"\n";
}
return 0;
}

1002

//多少个最长不上升子序列可以覆盖这个数列,其实是等效于最长上升子序列的长度
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 1100;
int n, h[MAXN], k[MAXN], ans1, ans2 = 1;
int dp1[MAXN], dp2[MAXN], maxn;
int main(){
ios::sync_with_stdio(false);
while(cin>>n){
memset(h,0,sizeof(h));
memset(dp1,0,sizeof(dp1));
memset(dp2,0,sizeof(dp2));
ans1 = 0; ans2 = 1;

for(int i = 0; i < n; i++)cin>>h[i];
dp1[0] = 1; dp2[0] = 1; k[0] = h[0];
for(int i = 1; i < n; i++){
//DP1
maxn = 0;
for(int j = 0; j < i; j++)
if(h[j]>=h[i])maxn = max(maxn, dp1[j]);
dp1[i] = maxn+1;
ans1 = max(ans1, dp1[i]);
//DP2
maxn = 0;
for(int j = 0; j < i; j++)
if(h[j]<=h[i])maxn = max(maxn, dp2[j]);
dp2[i] = maxn+1;
ans2 = max(ans2, dp2[i]);
}
//cout<<ans1<<"\n"<<ans2;
cout<<ans2<<"\n";
}
return 0;
}

1003

//f[i][j]表示到第i件物品时,选取2*j件物品的最低疲劳度
//首先贪心考虑相邻,肯定排序。
//转移,i==2*j,只能全选,此时f[i][j]=f[i-2][j-1]+(a[i]-a[i-1])^2。
//转移,i>2*j时,考虑第i件选和不选,若选则为当前结果,若不选则为之前的结果,f[i][j] = f[i-1][j];
#include<bits/stdc++.h>
using namespace std;
const int maxn = 2020;
int a[maxn], f[maxn][maxn];
int main(){
int n, k;
while(cin>>n>>k){
memset(a,0,sizeof(a));
memset(f,0,sizeof(f));
for(int i = 1; i <= n; i++)cin>>a[i];
sort(a+1,a+n+1);
for(int i = 1; i <= n; i++){
for(int j = 1; j <= k && 2*j<=i; j++){
if(i==2*j)f[i][j] = f[i-2][j-1]+(a[i]-a[i-1])*(a[i]-a[i-1]);
else f[i][j] = min(f[i-2][j-1]+(a[i]-a[i-1])*(a[i]-a[i-1]), f[i-1][j]);
}
}
cout<<f[n][k]<<"\n";
}
return 0;
}

1004

//维护a[t][x]表示第t秒位置x上有掉落,即转移的时候就是,纵向为时间,横向为位置的数塔。
#include<bits/stdc++.h>
using namespace std;
int n, a[100010][20], f[100010][20];
int main(){
while(cin>>n &&n){
memset(a,0,sizeof(a));
memset(f,0,sizeof(f));
int mx = -1;
for(int i = 1; i <= n; i++){
int x, t; cin>>x>>t;
a[t][x]++; mx=max(mx,t);
}
for(int i = mx; i >= 0; i--){//从底层开始往上走
for(int j = 0; j <= 10; j++){//枚举位置
if(j==0)f[i][j] = max(f[i+1][j],f[i+1][j+1])+a[i][j];//最左边
else f[i][j] = max(max(f[i+1][j],f[i+1][j+1]),f[i+1][j-1])+a[i][j];//左中右三个位置.
}
}
cout<<f[0][5]<<"\n";
}
return 0;
}

1005

//f[i]表示第i个丑数,并且一定由f[1~(i-1)] 中的数*2,3,5,7转移而来。
//考虑到是最小的,用优先队列维护,每次取出最小的*2,3,5,7即可,set维护重复值。
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int c[] = {2,3,5,7};
priority_queue<LL, vector<LL>, greater<LL> >q;
set<LL>se;
LL f[5900+10], cnt=0;

int main(){
q.push(1);
while(cnt<=5900){
LL t = q.top(); q.pop();
f[++cnt] = t;
for(int i = 0; i < 4; i++){
if(!se.count(t*c[i])){
se.insert(t*c[i]);
q.push(t*c[i]);
}
}
}

LL n;
while(cin>>n &&n){
cout<<f[n]<<"\n";
}
return 0;
}

1006

//f[i][j]表示到a[i]和b[j]为止的lCS。转移,显而易见。 
#include<bits/stdc++.h>
using namespace std;
int f[1010][1010];
int main(){
string a, b;
while(cin>>a>>b){
memset(f,0,sizeof(f));
for(int i = 0; i < a.size(); i++){
for(int j = 0; j < b.size(); j++){
if(a[i]==b[j])f[i+1][j+1] = f[i][j]+1;
else f[i+1][j+1] = max(f[i][j+1],f[i+1][j]);
}
}
cout<<f[a.size()][b.size()]<<"\n";
}
return 0;
}

1007

//f[i][j]表示到第i家公司为止,已经分配j台机器的最大收益
//转移:枚举为第i家公司分配1-z台机器的收益,此时前i-1家公司,分配j-z台机器。
#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int a[maxn][maxn], f[maxn][maxn];
int main(){
int n, m;
while(cin>>n>>m){
memset(a,0,sizeof(a));
memset(f,0,sizeof(f));
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
cin>>a[i][j];
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
int tmp = 0;
for(int z = 0; z <= j; z++)
tmp = max(tmp,f[i-1][z] + a[i][j-z]);
f[i][j] = tmp;
}
}
cout<<f[n][m]<<"\n";
}
return 0;
}

1008

//f[i]表示到第i个站时用的最少时间。
//转移的时候一定是从上个站点(1-(i-1))中的一个过来的,枚举这些站点,考虑充电和不充电的所用时间,并取最小。
#include<bits/stdc++.h>
using namespace std;
double a[1010], f[1010];
int main(){
double l;
int n; double c, t;
double vr, vt1, vt2;
while(cin>>l>>n>>c>>t>>vr>>vt1>>vt2){
for(int i = 1; i <= n; i++)cin>>a[i];
a[0] = 0; a[n+1] = l;//起点和终点

for(int i = 1; i <= n+1; i++){
double mi = 1e7+10;
for(int j = 0; j < i; j++){
double tt = 0;//充电用时
if(a[i]-a[j]>c)tt = c/vt1+(a[i]-a[j]-c)/vt2;//充电+脚步
else tt = (a[i]-a[j])/vt1;//全充满
if(j!=0)tt += t;
mi = min(mi,tt+f[j]);
}
f[i] = mi;
}
if(f[n+1]>l/vr)
cout<<"Good job,rabbit!\n";
else
cout<<"What a pity rabbit!\n";
}
return 0;
}

Practice 拓展1

1001

#include<bits/stdc++.h>
using namespace std;
int main(){
cout<<"Hello World\n";
return 0;
}

1002

#include<bits/stdc++.h>
using namespace std;
int main(){
int a, b;
cin>>a>>b;
cout<<a+b<<endl;
return 0;
}

1003

#include<bits/stdc++.h>
using namespace std;
int main(){
int a, b;
while(cin>>a>>b){
cout<<a+b<<"\n";
}
return 0;
}

1004

#include<bits/stdc++.h>
using namespace std;
int main(){
int T; cin>>T;
while(T--){
int a, b;
cin>>a>>b;
cout<<a+b<<endl;
}
return 0;
}

1005

#include<bits/stdc++.h>
using namespace std;
int main(){
int a, b;
while(cin>>a>>b &&a &&b){
cout<<a+b<<endl;
}
return 0;
}

1006

#include<bits/stdc++.h>
using namespace std;
int main(){
double a, b;
while(cin>>a>>b){
cout<<fixed<<setprecision(6)<<a*b<<endl;
}
return 0;
}

1007

#include<bits/stdc++.h>
using namespace std;
int main(){
double a, b;
while(cin>>a>>b){
cout<<"the answer is ";
if(a>0&&b>0)cout<<1;
if(a>0&&b<0)cout<<4;
if(a<0&&b>0)cout<<2;
if(a<0&&b<0)cout<<3;
cout<<".\n";
}
return 0;
}

1008

#include<bits/stdc++.h>
using namespace std;
int main(){
long long a,b,c;
while(cin>>a>>b>>c){
cout<<a+b-c<<endl;
}
return 0;
}

1009

#include<bits/stdc++.h>
using namespace std;
int main(){
int cnt = 1;
long long a,b,c;
while(cin>>a>>b){
cout<<"Case #"<<cnt++<<": ";
cout<<a+b<<endl;
}
return 0;
}

1010

#include<bits/stdc++.h>
using namespace std;
int main(){
char a;
while(cin>>a){
a -= 'a'-'A';
cout<<a<<endl;
}
return 0;
}

1011

#include<bits/stdc++.h>
using namespace std;
#define mod 10007
int f[10010];
int main(){
f[1] = 1;
for(int i = 2; i <= 10000; i++)
f[i] = f[i-1]*i%mod;
int n;
while(cin>>n){
cout<<f[n]<<endl;
}
return 0;
}

1012

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int n, a[maxn];
int main(){
while(cin>>n){
int sum = 0;
for(int i = 1; i <= n; i++)cin>>a[i],sum+=a[i];
cout<<sum<<endl;
for(int i = 1; i <= n; i++){
if(i!=1)cout<<" ";
cout<<a[i];
}

cout<<endl;
}
return 0;
}

1013

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int main(){
int ea, eb;
cin>>ea>>eb;
int a, b;
while(cin>>a>>b){
if(a==ea&&b==eb)break;
cout<<a+b<<endl;
}
return 0;
}

1014

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int f[maxn];
int main(){
int n;
int ea, eb;
//cin>>ea>>eb;
int a, b;
while(cin>>n){
for(int i = 1; i <= n; i++)cin>>f[i];
for(int i = n; i >= 1; i--){
if(i!=n)cout<<" ";
cout<<f[i];
}
cout<<endl;
}
return 0;
}

1015

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int f[maxn];
int main(){
int n;
int ea, eb;
//cin>>ea>>eb;
int a, b;
string s, t;
while(cin>>s){
cout<<s.size()<<endl;
cout<<s<<endl;
}
return 0;
}

1016

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int a[maxn][maxn];
int main(){
int n, m, sum = 0;
while(cin>>n>>m){
sum = 0;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
cin>>a[i][j];
sum += a[i][j];
}
}
cout<<sum<<endl;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
if(j!=1)cout<<" ";
cout<<a[i][j];
}
cout<<endl;
}
}
return 0;
}

1017

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
int a[maxn][maxn];
int main(){
int n, m, sum = 0;
while(cin>>n>>m){
memset(a,0,sizeof(a));
int cnt = 1, i = 1, j = 1; a[i][j]=1;
while(cnt<n*m){
while(j+1<=m && !a[i][j+1])a[i][++j]=++cnt;
while(i+1<=n && !a[i+1][j])a[++i][j]=++cnt;
while(j-1>=1 && !a[i][j-1])a[i][--j]=++cnt;
while(i-1>=1 && !a[i-1][j])a[--i][j]=++cnt;
}
for(int i = 1; i <= n; i++){
for(int j = 1 ; j<= m; j++){
if(j!=1)cout<<" ";
cout<<a[i][j];
}
cout<<endl;
}
}
return 0;
}

1018

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
//int a[maxn][maxn];
int f(int x){
return 3 * x - 6 * x * (x + 3) + 29 * (x + 2) * (x - 1);
}
int main(){
int a, b, c, d;
while(cin>>a>>b>>c>>d){
cout<<f(a)+f(b)+f(c)+f(d)<<endl;
}
return 0;
}

1019

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
//int a[maxn][maxn];
int F(int x){
return x*3+((x-1)*6+4)+3;
}

int G(int x){
return F(x)*2-F(x)*F(x-1);
}
int K(int x){
return G(x)*(G(2)-F(4));
}
int main(){
int a, b, c, d;
while(cin>>a>>b){
cout<<K(a)-K(b)<<endl;
}
return 0;
}

1020

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
//int a[maxn][maxn];
int F(int x){
if(x==1||x==2)return 1;
return F(x-1)+F(x-2);
}
int main(){
int a, b, c, d;
while(cin>>a){
cout<<F(a)<<endl;
}
return 0;
}

1021

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn = 1100;
LL f[maxn];
/*
int F(int x){
if(f[x])return f[x];
if(x==1||x==2)return f[x] = 1;
return f[x] = F(x-1)+F(x-2);
}
*/
int main(){
LL a, b, c, d;
f[1] = f[2] = 1;
for(int i = 3; i <= 100; i++)
f[i] = f[i-1]+f[i-2];
while(cin>>a){
cout<<f[a]<<endl;
}
return 0;
}

1022

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1100;
int f[maxn][maxn];
/*
int F(int x){
if(f[x])return f[x];
if(x==1||x==2)return f[x] = 1;
return f[x] = F(x-1)+F(x-2);
}
*/
int a[maxn];
bool cmp(int a, int b){return a>b;}
int main(){
/*
int n;
while(cin>>n){
for(int i = 1; i <= n; i++)cin>>a[i];
sort(a+1,a+n+1,cmp);
for(int i = 1; i <= n; i++){
if(i!=1)cout<<" ";
cout<<a[i];
}
cout<<endl;
}
*/
cout<<"JuShenNiuBi";
return 0;
}

1023

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1100;
int f[maxn][maxn];
/*
int F(int x){
if(f[x])return f[x];
if(x==1||x==2)return f[x] = 1;
return f[x] = F(x-1)+F(x-2);
}
*/
int main(){
for(int i = 1 ; i < 30; i++)f[i][1] = f[1][i] = f[0][i] = 1;

for(int i = 1; i <= 30; i++)
for(int j = 1; j <= 30; j++)
if(i>=j)f[i][j] = f[i][j-1]+f[i-j][j];
else f[i][j] = f[i][j-1];
int a, b;
while(cin>>a>>b){
cout<<f[a][b]<<endl;
}
return 0;
}

1024

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1100;
int f[maxn][maxn];
/*
int F(int x){
if(f[x])return f[x];
if(x==1||x==2)return f[x] = 1;
return f[x] = F(x-1)+F(x-2);
}
*/
int a[maxn];
bool cmp(int a, int b){return a>b;}
int main(){
int n;
while(cin>>n){
for(int i = 1; i <= n; i++)cin>>a[i];
sort(a+1,a+n+1,cmp);
for(int i = 1; i <= n; i++){
if(i!=1)cout<<" ";
cout<<a[i];
}
cout<<endl;
}
return 0;
}

Practice 拓展2

1001

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn = 1100;
map<string,string>ma;
int main(){
int n, m;
while(cin>>n>>m){
for(int i = 1; i <= n; i++){
string a,b;
cin>>a>>b;
ma[a] = b;
}
for(int i = 1; i <= m; i++){
string t;
cin>>t;
if(ma.count(t))cout<<ma[t]<<"\n";
else cout<<"aoaoaonb\n";
}
}
return 0;
}

1002

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn = 1100;
int main(){
int n;
while(cin>>n &&n){
queue<int>q;
for(int i = 1; i <= n; i++){
int x; cin>>x; q.push(x);
}
while(q.size()>1){
q.pop();
int t = q.front();
q.pop();
q.push(t);
}
cout<<q.front()<<endl;
}
return 0;
}

1003

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
int main(){
//freopen("test.cpp","r",stdin);
vector<LL>vec;
LL k, sum = 0;
while(cin>>k &&k){
if(k==1){
LL x; cin>>x;
vec.push_back(x);
sum += x;
}else if(k==2){
if(vec.size()==0)cout<<"No money!\n";
else{
cout<<vec.back()<<" "<<vec.size()-1<<" "<<sum-vec.back()<<"\n";
sum -= vec.back();
vec.pop_back();
}
}else{
cout<<vec.size()<<" "<<sum<<endl;
vec.clear();
sum = 0;
}
}
return 0;
}

1004

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n, m;
while(cin>>n>>m){
vector<int>vec[10010];
for(int i = 1; i <= n; i++){
int a, b;
cin>>a>>b;
vec[a].push_back(b);
}
for(int i = 1; i<= m; i++){
if(vec[i].size()==0)continue;
sort(vec[i].begin(), vec[i].end());
if(vec[i].size()%2==1)printf("%.3f\n",vec[i][(vec[i].size()-1)/2]*1.0);
else printf("%.3f\n",(vec[i][vec[i].size()/2]+vec[i][(vec[i].size()-1)/2])*1.0/2);
}
}
return 0;
}

1005

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n;
while(cin>>n){
priority_queue<int>q;
for(int i = 1; i <= n; i++){
char ch; cin>>ch;
if(ch=='Q'){
int x; cin>>x;
q.push(x);
}else{
if(q.size()!=0){
cout<<q.top()<<endl;
q.pop();
}
else cout<<"AK!\n";
}
}
}
return 0;
}

1006

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n;
while(cin>>n){
deque<LL>q;
for(int i = 1; i <= n; i++){
LL op, x; cin>>op>>x;
if(op==0){
q.push_front(x);
}else{
q.push_back(x);
}
}
vector<LL>vec(q.begin(),q.end());
//sort(vec.begin(),vec.end());
double ans = 0;
if(vec.size()%2==1){
ans = vec[(vec.size()-1)/2]*1.0;
}else{
ans = (vec[vec.size()/2]+vec[vec.size()/2-1])/2.0;
}
printf("%.3lf\n",ans);
//if(vec.size()%2==1)printf("%.3f\n",vec[(vec.size()-1)/2]*1.0);
//else printf("%.3f\n",(vec[vec.size()/2+1]+vec[vec.size()/2])/2.0);
}
return 0;
}

1007

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n;
while(cin>>n){
set<string>se;
for(int i = 1; i <= n; i++){
string str; cin>>str;
se.insert(str);
}
cout<<se.size()<<endl;
}
return 0;
}

1008

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
string s;
while(cin>>s){
cout<<count(s.begin(),s.end(),'a')<<endl;
}
return 0;
}

1009

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n;
while(cin>>n){
int sum = 0;
for(int i = 1; i <= n; i++){
int x; cin>>x; sum+= x;
}
printf("%.4lf\n",sum*1.0/n);
}
return 0;
}

1010

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n;
while(cin>>n){
int mx = -1, mi = 1e9;
for(int i = 1; i <= n; i++){
int x; cin>>x;
mx = max(x,mx);
mi = min(x,mi);
}
cout<<mx-mi<<endl;
}
return 0;
}

1011

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int x;
while(cin>>x){
int ans = 0;
while(x>0){
ans += x%10;
x /= 10;
}
cout<<ans<<endl;
}
return 0;
}

1012

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n, m;
while(cin>>n>>m){
int a[50][50];
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
cin>>a[i][j];
}
}
int ans = -1e9;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
for(int r = i; r <= n; r++){
for(int c = j; c <= m; c++){
int tmp = 0;
for(int ii = i; ii <= r; ii++){
for(int jj = j; jj <= c; jj++){
tmp += a[ii][jj];
}
}
ans = max(ans,tmp);
}
}
}
}
cout<<ans<<endl;
}
return 0;
}

1013

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
double xa, ya, xb, yb, xc, yc;
while(cin>>xa>>ya>>xb>>yb>>xc>>yc){
if(xa==xb){
if(xb==xc)cout<<"YES\n";
else cout<<"NO\n";
continue;
}
if(ya==yb){
if(yb==yc)cout<<"YES\n";
else cout<<"NO\n";
continue;
}
double k1 = (yb-ya)/(xb-xa);
double k2 = (yc-ya)/(xc-xa);
if(abs(k1-k2)<1e-4)printf("YES\n");
else printf("NO\n");
}
return 0;
}

1014

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n;
while(cin>>n){
char a[20][20];
memset(a,0,sizeof(a));
int cnt = 'a';
for(int i = 1; i <= n; i++){
if(cnt>'z') cnt = 'a';
a[i][1] = cnt++;
}
for(int i = n-1,j=2; i >= 2; i--,j++){
if(cnt>'z') cnt = 'a';
a[i][j] = cnt++;
}
for(int i = 1; i <= n; i++){
if(cnt>'z') cnt = 'a';
a[i][n] = cnt++;
}
for(int i = 1; i <= n; i++){
for(int j =1 ; j<= n; j++){
if(a[i][j]!=0)printf("%c",a[i][j]);
else printf(" ");
}
cout<<endl;
}
}
return 0;
}

1015

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
string s;
while(cin>>s){
for(int i = 0 ; i < s.size(); i++){
if(s[i]>='a'&&s[i]<='z'){
printf("%c",s[i]-('a'-'A'));
//cout<<s[i]-('a'-'A');
}else cout<<s[i];
}
cout<<endl;
}
return 0;
}

1016

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
int n; //cin>>n;
string s[110];
while(cin>>n){
for(int i = 1; i <= n; i++)cin>>s[i];
sort(s+1,s+n+1);
cout<<s[n]<<endl;
}
return 0;
}

1017

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

LL a, n;
LL F(LL x){
if(x==1)return a;
return (x % 2 == 0) ? F(x / 2) + 1 : F((x + 1) / 2) * 3 - 2;
}

int main(){
//freopen("test.cpp","r",stdin);
while(cin>>a>>n){
cout<<F(n)<<endl;
}
return 0;
}

1018

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

int main(){
//freopen("test.cpp","r",stdin);
string s;
while(cin>>s){
for(int i = 1; i <= s.size(); i++){
if(s.size()%i!=0)continue;
int ok = 1;
for(int j = 0; j < s.size(); j++){
if(s[j]!=s[j%i]){ok=0;break;}
}
if(ok){
cout<<i<<endl;
break;
}
}
}
return 0;
}

1019

1020

1021

#include<bits/stdc++.h>
using namespace std;
const int maxn = 100010;
int a[maxn], b[maxn];
int main(){
int T; cin>>T;
while(T--){
int n, k;
cin>>n>>k;
for(int i = 0; i < n; i++)cin>>a[i];
for(int i = 0; i < n; i++)cin>>b[i];
int ans = 0;
for(int i = 0; i < n; i++){
int tmp = 2;
tmp += abs(a[i]-b[i]);
tmp += abs(a[i]-b[(i+1)%n]);
cout<<tmp<<endl;
ans += tmp;
}
cout<<ans<<endl;
}
return 0;
}

1022

#include<bits/stdc++.h>
using namespace std;
int Youxianji(char op){
if(op=='*'||op=='/')return 2;
if(op=='+'||op=='-')return 1;
if(op=='(')return 0;
}
void ToHouzhui(string str, string& ans){
stack<char>stk;
ans = "";
int i =0;
while(i<str.size()){
if(str[i]>='0' && str[i]<='9'){
//ans += str[i];
int t = 0;
while(str[i]>='0' && str[i]<='9'){
t = t*10+str[i]-'0';
i++;
}
ans += to_string(t)+".";
}else{
if(stk.empty()){
stk.push(str[i]);
}else if(str[i]=='('){
stk.push(str[i]);
}else if(str[i]==')'){
while(stk.top()!='('){
ans += stk.top();
stk.pop();
}
stk.pop();
}else{
while(Youxianji(stk.top())>=Youxianji(str[i])){
ans += stk.top();
stk.pop();
if(stk.empty())break;
}
stk.push(str[i]);
}
i++;
}
}
while(stk.size()){
ans += stk.top();
stk.pop();
}
}
int culate(string str){
stack<int>stk;
int ans = 0, i = 0;
while(i < str.size()){
if(str[i]>='0'&&str[i]<='9'){
//stk.push(str[i]-'0');
int t = 0;
while(str[i]!='.'){
t = t*10+str[i]-'0';
i++;
//cout<<t<<endl;
}
i++;
//cout<<t<<endl;
stk.push(t);
}else{
int a = stk.top(); stk.pop();
int b = stk.top(); stk.pop();
int tmp;
if(str[i]=='+')tmp = b+a;
if(str[i]=='-')tmp = b-a;
if(str[i]=='*')tmp = b*a;
if(str[i]=='/')tmp = b/a;
stk.push(tmp);
i++;
}
}
return stk.top();
}

int main(){
string s,t;
while(cin>>s){
ToHouzhui(s,t);
//cout<<t<<endl;
cout<<culate(t)<<endl;
}
return 0;
}

1023

#include<bits/stdc++.h>
using namespace std;
char mp[100][100];
int main(){
int T; cin>>T;
while(T--){
fill(mp[0],mp[0]+100*100,'.');
int a, b, c;
cin>>a>>b>>c;
//V
for(int i = b*2+1; i <= (b+c)*2+1; i++){
for(int j = 1; j <= a*2+1; j++){
if(i%2==1){
if(j%2==1){
mp[i][j] = '+';
}else{
mp[i][j] = '-';
}
}else{
if(j%2==1){
mp[i][j] = '|';
}
}
}
}
//H
for(int i = 1; i <= 2*b; i++){
for(int j = 2*(b+1)-i; j <= (2*(b+1)-i)+2*a; j++){
if(i%2==1){
if(j%2==1){
mp[i][j] = '+';
}else{
mp[i][j] = '-';
}
}else{
if(j%2==0){
mp[i][j] = '/';
}
}
}
}
//W
for(int j = 2*a+1; j <= (a+b)*2+1; j++){
for(int i = 2*(a+b+1)-j; i <= (2*(a+b+1)-j)+2*c; i++){
if(i%2==1){
if(j%2==1){
mp[i][j] = '+';
}
}else{
if(j%2==1){
mp[i][j] = '|';
}else{
mp[i][j] = '/';
}
}
}
}
//
for(int i = 1; i <= (b+c)*2+1; i++){
for(int j = 1; j <= (a+b)*2+1; j++){
cout<<mp[i][j];
}
cout<<endl;
}

}
return 0;
}

1024

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1010;
int a[maxn];
int main(){
int n, m;
while(cin>>n>>m){
for(int i = 1; i <= n; i++)cin>>a[i];
for(int i = 1; i <= m; i++)next_permutation(a+1,a+n+1);
for(int i = 1; i <= n; i++){
if(i!=1)cout<<" ";
cout<<a[i];
}
cout<<endl;
}
return 0;
}

1025

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1010;
int a[maxn];
int main(){
printf("Hello World\n");
return 0;
}


精彩评论(0)

0 0 举报