蒟蒻求助QAQ
  • 板块灌水区
  • 楼主taotao2007
  • 当前回复0
  • 已保存回复0
  • 发布时间2020/12/31 15:03
  • 上次更新2023/11/5 05:27:55
查看原帖
蒟蒻求助QAQ
304681
taotao2007楼主2020/12/31 15:03

蒟蒻问大佬道题,不是洛谷上的
十字方阵
2^n-1行和2^n-1列构成
样例输入
3
样例输出
+|+|-|+
-+-|-+-
+|+|+|+
---+---
+|+|+|+
-+-|-+-
+|+|+|+
我的程序是这样的:

#include<bits/stdc++.h>
using namespace std;
char pic[100][100];
int n,key;
void initi(){
	for(int i=1;i<=key;i++){
		for(int j=1;j<=key;j++){
			if(j%2!=0)pic[i][j]='-';
			else pic[i][j]='|';
		}
	}
	for(int i=1;i<=key;i++)pic[key/2+1][i]='-';
}
void print(){
	for(int i=1;i<=key;i++){
		for(int j=1;j<=key;j++){
			cout<<pic[i][j];
		}
		cout<<endl;
	}
}
void draw(int k,int x,int y){
	if(k%2==0)return;
	pic[x][y]='+';
	draw(k/2,x-k/2,y-k/2);
	draw(k/2,x+k/2,y-k/2);
	draw(k/2,x-k/2,y+k/2);
	draw(k/2,x+k/2,y+k/2);
}
int main(){
    cin>>n;
    key=pow(2,n)-1;
    initi();
	draw(key,key/2+1,key/2+1);
	print();
	return 0;
}

输出出来不对 求大神赐教

2020/12/31 15:03
加载中...