| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 861 人关注过本帖
标题:数组与结构体的区别,poj 1118,求解
取消只看楼主 加入收藏
搬砖
Rank: 2
等 级:论坛游民
帖 子:68
专家分:37
注 册:2016-10-13
结帖率:90%
收藏
已结贴  问题点数:20 回复次数:1 
数组与结构体的区别,poj 1118,求解
poj 1118,我用数组会编辑错误,但用结构体却ac了
      给出n个坐标,求最多有多少点在同一直线上。
代码如下
数组的
#include<stdio.h>
int main()
{
    int n,i,j,k,max,p,x[n],y[n];
    while(scanf("%d",&n)&&n!=0)
    {
        max=0;
        for(i=0;i<n;i++)
            scanf("%d%d",&x[i],&y[i]);
        for(i=0;i<n;i++)
            for(j=i+1;j<n;j++)
            {
                p=0;
                for(k=j+1;k<n;k++)
                {
                   if ((y[i]-y[k])*(x[i]-x[j])==(y[i]-y[j])*(x[i]-x[k]))
                        p++;
                }
                if(p>max)
                    max=p;
            }
        printf("%d\n",max+2);
    }
    return 0;
}



结构体的
#include<stdio.h>
struct node
{
    int x;
    int y;
}point[701];
int main()
{
    int n,i,j,k,max,p;
    while(scanf("%d",&n)&&n!=0)
    {
        max=0;
        for(i=0;i<n;i++)
            scanf("%d%d",&point[i].x,&point[i].y);
        for(i=0;i<n;i++)
            for(j=i+1;j<n;j++)
            {
                p=0;
                for(k=j+1;k<n;k++)
                {
                    if((point[i].x-point[j].x)*(point[i].y-point[k].y)==(point[i].x-point[k].x)*(point[i].y-point[j].y))
                        p++;
                }
                if(p>max)
                    max=p;
            }
        printf("%d\n",max+2);
    }
    return 0;
}
样例
5
1 1
2 2
3 3
9 10
10 11
0
输出
3
搜索更多相关主题的帖子: include 结构体 
2016-12-29 23:16
搬砖
Rank: 2
等 级:论坛游民
帖 子:68
专家分:37
注 册:2016-10-13
收藏
得分:0 
回复 2楼 九转星河
改了。。。过了。。。
多谢
2016-12-30 09:47
快速回复:数组与结构体的区别,poj 1118,求解
数据加载中...
 
   



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

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