计算直线的交点数

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 9357    Accepted Submission(s): 4226

Problem Description
平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。 比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行)。
 
Input
输入数据包含多个测试实例,每个测试实例占一行,每行包含一个正整数n(n<=20),n表示直线的数量.
 
Output
每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能的交点数,每行的整数之间用一个空格隔开。
 
Sample Input
2
3
 
Sample Output
0 1
0 2 3
 

题解:用st存一下i条直线的点数目的种类;然后枚举平行线的条数j;当前点的个数就是*iter+平行的*不平行的,画个图看下就好了;

想了下,写下就过了;有点dp的意思

代码:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<set>
using namespace std;
set<int>st[];
set<int>::iterator iter;
void db(){
st[].insert();
for(int i = ; i < ; i++){
st[i].insert();
for(int j = ; j < i; j++){
for(iter = st[i - j].begin(); iter != st[i - j].end(); iter++){
int dot = *iter + (i - j) * j;
st[i].insert(dot);
}
}
} }
int main(){
int n;
db();
while(~scanf("%d", &n)){
for(iter = st[n].begin(); iter != st[n].end(); iter++){
if(iter != st[n].begin())printf(" ");
printf("%d", *iter);
}
puts("");
}
return ;
}

java:

package com.lanqiao.week1;

import java.util.Arrays;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Scanner;
import java.util.Set; public class hdu1466 {
private static Scanner cin = null;
static Set<MyInteger>[] set = null;
static MyInteger[][] arr = new MyInteger[25][];
private static final int MAXN = 25;
static{
cin = new Scanner(System.in);
set = new HashSet[MAXN];
}
static class MyInteger implements Comparable{
int v;
@Override
public int hashCode() {
return v;
}
public int getV() {
return v;
}
public MyInteger(int v) {
super();
this.v = v;
}
@Override
public String toString() {
return v + "";
}
@Override
public boolean equals(Object obj) {
MyInteger t = (MyInteger)obj;
return t.v == this.v;
}
@Override
public int compareTo(Object o) {
MyInteger t = (MyInteger)o;
return this.v - t.getV();
}
}
private static void getSet(){
for(int i = 0; i < MAXN; i++){
set[i] = new HashSet<MyInteger>(){};
}
set[1].add(new MyInteger(0));
for(int i = 2; i < MAXN; i++){
set[i].add(new MyInteger(0));
for(int j = 1; j < i; j++){
Iterator<MyInteger> iter = set[i - j].iterator();
while(iter.hasNext()){
//System.out.println("zz");
set[i].add(new MyInteger(iter.next().getV() + j * (i - j)));
}
}
}
for(int i = 1; i < MAXN; i++){
arr[i] = new MyInteger[set[i].size()];
set[i].toArray(arr[i]);
Arrays.sort(arr[i]);
}
}
public static void main(String[] args) {
getSet();
while(cin.hasNext()){
int N = cin.nextInt(); for(int i = 0; i < arr[N].length; i++){
if(i != 0){
System.out.print(" ");
}
System.out.print(arr[N][i].getV());
}System.out.println();
}
}
}

计算直线的交点数(set + 打表)的更多相关文章

  1. HDU-1466 计算直线的交点数 经典dp

    1.HDU-1466   计算直线的交点数 2.链接:http://acm.hdu.edu.cn/showproblem.php?pid=1466 3.总结:不会推这个,看了题解.. 状态转移: m条 ...

  2. hdu----(1466)计算直线的交点数(dp)

    计算直线的交点数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  3. HDOJ 1466 计算直线的交点数

    将n 条直线排成一个序列,直线2和直线1最多只有一个交点,直线3和直线1,2最多有两个交点,......,直线n 和其他n-1条直线最多有n-1个交点.由此得出n条直线互不平行且无三线共点的最多交点数 ...

  4. G题 hdu 1466 计算直线的交点数

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1466 计算直线的交点数 Time Limit: 2000/1000 MS (Java/Others)  ...

  5. C++ 计算直线的交点数(动态规划)

    问题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1466 Problem Description 平面上有n条直线,且无三线共点,问这些直线能有多少种不同 ...

  6. hdu1466计算直线的交点数 非原创

    原文链接 平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数. 比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行). Input输入数据包含多个测试实例,每个测试实例占一行,每 ...

  7. 计算直线的交点数(hdu1466简单的dp)

    题意:平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数.比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行). 思路:动态规划,想办法记忆化搜索,当前状态和之前状态结合起来 d ...

  8. hdu1466 计算直线的交点数

    题意: 平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数. 比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行). 分析: DP 设状态:f[i][j]表示i条直线能否产生j个 ...

  9. hdu 1466 计算直线的交点数

    http://acm.hdu.edu.cn/showproblem.php?pid=1466 N条直线的交点方案数 = c 条直线交叉的交点数与(N-c)条平行线 + c 条直线本身的交点方案 = ( ...

随机推荐

  1. linux 终止用户会话

    第一步使用 tty 命令 查看自己会话id:本例中会话id为1[root@localhost ~]# tty/dev/pts/1[root@localhost ~]# 第二步 使用 w 命令 查看当前 ...

  2. ssh命令

    使用ssh命令登陆远程系统 ssh [ip/address] -l [登陆用户名] 如: ssh www.xyz.cn -l root

  3. EF中的约定

    优先级:Fluent API >数据注释>约定 CodeFirst约定 主键约定 如果类的属性名为"ID"(不区分大小写)或类名的后面跟有"ID", ...

  4. 一个Banner广告收缩效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. CSS 设计模式一 元素

    1.background  内置 是一种CSS内置设计模式,支持在元素下显示图片 HTML <!DOCTYPE html> <html lang="en"> ...

  6. OC基础 可变数组与不可变数组的使用

    OC基础 可变数组与不可变数组的使用 1.不可变数组 1.1不可变数组的创建 //实例方法 NSArray *array = [[NSArray alloc] initWithObjects:&quo ...

  7. hdu4296 贪心

    E - 贪心 Crawling in process... Crawling failed Time Limit:2000MS     Memory Limit:32768KB     64bit I ...

  8. 洛谷 P1656 炸铁路

    P1656 炸铁路 题目提供者kkksc03 标签图论搜索/枚举洛谷原创 难度普及/提高- 题目描述 因为某国被某红色政权残酷的高压暴力统治.美国派出将军uim,对该国进行战略性措施,以解救涂炭的生灵 ...

  9. CODEVS 1062 路由选择

    1062 路由选择  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题目描述 Description 在网络通信中,经常需要求最短路径.但完全用最短路径传 ...

  10. setTimeout与setInterval方法的区别

    setTimeout与setInterval方法的区别 setTimeout()用于设定在指定的时间之后执行对应的函数或代码.,在全局作用域下执行 setTimeout(code,time[,args ...