UVA201正方形squares

用两个数组存水平线和竖直线,然后先枚举正方形的边长,然后对于每个边长枚举方格内的所有顶点,对于每个顶点,向右枚举处于同一水平边和对边的点,向下枚举处于同一竖直边和对边的点,如果枚举过程中任何一个顶点未在对应数组中有记录,说明该点不存在连线,自然不可组成正方形,否则遍历能正常结束,说明所有点都有连线,计数加1,输出当前边长的正方形数

#include <iostream>

#include <cstring>

using namespace std;

int main()

{

ios::sync_with_stdio(false);

int v[11][11],h[11][11]; //分别存竖直线和水平线

int m,n,k=0;

while(k++,cin>>n>>m)

{

bool noans=true; //标记是否有正方形

memset(v,0,sizeof(v));

memset(h,0,sizeof(h));

char mode;

int a,b;

for(int i=0;i<m;i++)

{

cin>>mode>>a>>b;

if(mode=='H')

h[a][b]++; //将线段信息存入数组

else

v[b][a]++; //这里按照紫书的描述应该是v[a][b],但是原题不是这样。。。坑

}

if(k!=1)

cout<<endl<<"**********************************"<<endl<<endl;

cout<<"Problem #"<<k<<endl<<endl;

for(int s=1;s<n;s++) //枚举边长

{

int cont=0;

for(int i=1;i<=n-s;i++) //枚举左上顶点

for(int j=1;j<=n-s;j++)

{

bool mark=true; //标记当前顶点是否可能有当前边长的正方形

for(int x=i,y=j;mark&&x<i+s;x++)

if(!v[x][y]||!v[x][y+s]) //任何一点无连线则不可能组成正方形

mark=false;

for(int x=i,y=j;mark&&y<j+s;y++)

if(!h[x][y]||!h[x+s][y])

mark=false;

if(mark) //可组成正方形则当前边长正方形数量累加

cont++;

}

if(cont)

{

cout<<cont<<" square (s) of size "<<s<<endl;

noans=false;

}

}

if(noans) //无结果

cout<<"No completed squares can be found."<<endl;

}

 

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `squares.append()`是Python语言中列表对象的一个方法,用于在列表末尾添加一个元素。例如,如果你有一个名为"squares"的列表,并且想在其末尾添加数字9,你可以使用以下代码: ``` squares.append(9) ``` 这将在列表末尾添加数字9。 ### 回答2: 在Python中,squares.append()是一个列表方法,用于向列表中添加元素。该方法接受一个参数,即要添加的元素,并将该元素添加到列表的末尾。 例如,假设我们有一个空列表squares。我们可以使用以下代码将一个元素添加到列表中: squares = [] squares.append(4) 现在,squares列表将包含一个元素,即数字4。我们可以进一步使用append()方法来添加更多的元素到列表中。例如: squares.append(9) squares.append(16) squares.append(25) 现在,squares列表将依次包含数字4、9、16和25。 总结而言,squares.append()是一个有用的列表方法,它允许我们在Python中向列表中添加元素。无论列表是否为空,我们都可以使用append()方法将元素添加到列表的末尾。 ### 回答3: `python squares.append`是Python语言中的一个方法,用于将一个元素追加到列表(list)中。在使用该方法时,需要先创建一个列表对象,并且可以在括号内指定要追加的元素。 例如,以下是一个使用`squares.append`的示例: ```python squares = [] # 创建一个空的列表对象 # 使用append方法将元素依次追加到列表中 squares.append(1) squares.append(4) squares.append(9) squares.append(16) print(squares) # 输出结果为:[1, 4, 9, 16] ``` 在上述示例中,我们首先创建了一个空的列表对象`squares`。然后,使用`squares.append`方法依次向列表中追加了四个元素,分别是1、4、9和16。最后,通过`print(squares)`将列表内容打印输出,结果为`[1, 4, 9, 16]`。 总而言之,`python squares.append`是用于将一个元素追加到列表中的Python方法,可以方便地扩充列表的内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值