| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 582 人关注过本帖
标题:关于二维数组做参数的问题(附加一题)
取消只看楼主 加入收藏
幽幽球
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-1
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:1 
关于二维数组做参数的问题(附加一题)
【问题描述】

将一个矩形划分成N*M(1 <= N <= 2000,1 <= M <= 2000)个格子,每个格子有被占用和未被占用两种情况。将一个边长为i的正方形放入矩形中,要求正方形区域中不包含被占用的格子,问共有多少种合适的放置方案。

【输入数据和形式】

从标准输入读取一个整数i (1 < i <= min(M,N)),表示正方形的边长。之后读取N行,每行有M个整数,取值为0或1(1表示该格未被占用,0表示该格被占用)。

【输出数据和形式】

将矩形的放置方案数写到标准输出。

【输入样例】

2

1011

1111

1110

1110

【输出样例】

5
我写的...
#include <stdio.h>
#include <string.h>
char str[2000][2000];
int i;
int is_carre(char **str,int k,int m)
{
    int e,f;
    for (e=k;e<=k+i-1;e++)
        for(f=m;f<=m+i-1;f++)
            if (str[e][f]=='0')
                break;
            
    if(e==i&&f==i)
        return 1;
    else
        return 0;
}
int main()
{
    int numl=0,M,N,j=0,total,k,m,num=0; //str[k][m]
    char c,a[1000]={'\0'};
    scanf("%d",&i);
    while ((c=getchar())!=EOF)
    {
        if(c=='0'||c=='1')
        a[j++]=c;
        else if (c=='\n')
        numl++;
        else break;
    }
    //puts(a);
    M=numl;                         //M行
    total=strlen(a);
    N=total/numl;                   //N列
    //printf("%d %d",N,total);
    for(k=0;k<M;k++)
        for(m=0,j=k*N ; m<N,j<=(k+1)*N-1 ; m++,j++)
            str[k][m]=a[j];         //至此已经把a[]存成二维数组
    if (i<=M&&i<=N)
    {
        for(k=0;k<=M-i;k++){
            for(m=0;m<N-i;m++){
                if (is_carre(str,k,m)==1)
                    num++;
                else continue;}}
    }
    else
        printf("ERROR!");
    printf("%d",num);
    return 0;
}
就是那个is_carre函数像调用二维数组str[][],不知道怎么掉...这个程序运行什么都是0...
搜索更多相关主题的帖子: 正方形 
2011-06-01 22:52
幽幽球
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-1
收藏
得分:0 
回复 2楼 thlgood
谢谢啦~改过来了,但是程序有问题啊,根本进不了那个is_carre的循环...大神能否帮忙看看代码...(帮帮小白吧~
程序代码:
#include <stdio.h>
#include <string.h>
char str[2000][2000];
int i;
int (*p)[2000][2000] = str;

int is_carre(int *p,int k,int m)
{
    int e,f;
    for (e=k;e<=k+i-1;e++)
        for(f=m;f<=m+i-1;f++)
            if (str[e][f]=='0')
                break;
           
    if(e==i&&f==i)
        return 1;
    else
        return 0;
}
int main()
{
    int numl=0,M,N,j=0,total,k,m,num=0; //str[k][m]
    char c,a[1000]={'\0'};
    scanf("%d",&i);
    while ((c=getchar())!=EOF)
    {
        if(c=='0'||c=='1')
        a[j++]=c;
        else if (c=='\n')
        numl++;
        else break;
    }
    //puts(a);
    M=numl;                         //M行
    total=strlen(a);
    N=total/numl;                   //N列
    //printf("%d %d",N,total);
    for(k=0;k<M;k++)
        for(m=0,j=k*N ; m<N,j<=(k+1)*N-1 ; m++,j++)
            str[k][m]=a[j];         //至此已经把a[]存成二维数组
    if (i<=M&&i<=N)
    {
        for(k=0;k<=M-i;k++){
            for(m=0;m<N-i;m++){
                if (is_carre(p,k,m)==1)
                    num++;
                else continue;}}
    }
    else
        printf("ERROR!");
    printf("%d",num);
    return 0;
}
2011-06-02 09:18
快速回复:关于二维数组做参数的问题(附加一题)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025306 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved