计算直线的交点数(set + 打表)
计算直线的交点数
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 9357 Accepted Submission(s): 4226
3
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 + 打表)的更多相关文章
- HDU-1466 计算直线的交点数 经典dp
1.HDU-1466 计算直线的交点数 2.链接:http://acm.hdu.edu.cn/showproblem.php?pid=1466 3.总结:不会推这个,看了题解.. 状态转移: m条 ...
- hdu----(1466)计算直线的交点数(dp)
计算直线的交点数 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- HDOJ 1466 计算直线的交点数
将n 条直线排成一个序列,直线2和直线1最多只有一个交点,直线3和直线1,2最多有两个交点,......,直线n 和其他n-1条直线最多有n-1个交点.由此得出n条直线互不平行且无三线共点的最多交点数 ...
- G题 hdu 1466 计算直线的交点数
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1466 计算直线的交点数 Time Limit: 2000/1000 MS (Java/Others) ...
- C++ 计算直线的交点数(动态规划)
问题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1466 Problem Description 平面上有n条直线,且无三线共点,问这些直线能有多少种不同 ...
- hdu1466计算直线的交点数 非原创
原文链接 平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数. 比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行). Input输入数据包含多个测试实例,每个测试实例占一行,每 ...
- 计算直线的交点数(hdu1466简单的dp)
题意:平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数.比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行). 思路:动态规划,想办法记忆化搜索,当前状态和之前状态结合起来 d ...
- hdu1466 计算直线的交点数
题意: 平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数. 比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行). 分析: DP 设状态:f[i][j]表示i条直线能否产生j个 ...
- hdu 1466 计算直线的交点数
http://acm.hdu.edu.cn/showproblem.php?pid=1466 N条直线的交点方案数 = c 条直线交叉的交点数与(N-c)条平行线 + c 条直线本身的交点方案 = ( ...
随机推荐
- linux 终止用户会话
第一步使用 tty 命令 查看自己会话id:本例中会话id为1[root@localhost ~]# tty/dev/pts/1[root@localhost ~]# 第二步 使用 w 命令 查看当前 ...
- ssh命令
使用ssh命令登陆远程系统 ssh [ip/address] -l [登陆用户名] 如: ssh www.xyz.cn -l root
- EF中的约定
优先级:Fluent API >数据注释>约定 CodeFirst约定 主键约定 如果类的属性名为"ID"(不区分大小写)或类名的后面跟有"ID", ...
- 一个Banner广告收缩效果
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- CSS 设计模式一 元素
1.background 内置 是一种CSS内置设计模式,支持在元素下显示图片 HTML <!DOCTYPE html> <html lang="en"> ...
- OC基础 可变数组与不可变数组的使用
OC基础 可变数组与不可变数组的使用 1.不可变数组 1.1不可变数组的创建 //实例方法 NSArray *array = [[NSArray alloc] initWithObjects:&quo ...
- hdu4296 贪心
E - 贪心 Crawling in process... Crawling failed Time Limit:2000MS Memory Limit:32768KB 64bit I ...
- 洛谷 P1656 炸铁路
P1656 炸铁路 题目提供者kkksc03 标签图论搜索/枚举洛谷原创 难度普及/提高- 题目描述 因为某国被某红色政权残酷的高压暴力统治.美国派出将军uim,对该国进行战略性措施,以解救涂炭的生灵 ...
- CODEVS 1062 路由选择
1062 路由选择 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在网络通信中,经常需要求最短路径.但完全用最短路径传 ...
- setTimeout与setInterval方法的区别
setTimeout与setInterval方法的区别 setTimeout()用于设定在指定的时间之后执行对应的函数或代码.,在全局作用域下执行 setTimeout(code,time[,args ...