hdu1466(dp)

Problem Description
平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。
比如,如果n=2,则可能的交点数量为0(平行)或者1(不平行)。

Input
输入数据包含多个测试实例,每个测试实例占一行,每行包含一个正整数n(n<=20),n表示直线的数量.

Output
每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能的交点数,每行的整数之间用一个空格隔开。

Sample Input
2 3

Sample Output
0 1 0 2 3


题目看起来很水,思路其实很简单!不过也需要非常严谨的思路才能想对。。。。

首先n条线段,全部平行,0;

n-1条线段平行,n-1;

n-2条线段平行,2*(n-2)+2条线段的交点数;

n-3条线段平行,3*(n-3)+3条线段的交点数;

n-4条线段平行,4*(n-4)+4条线段的交点数;

………………………………

以此类推!


上面我写的     “+2条线段的交点数;”      这个部分需要注意!恰好是我们可以记录下来的前面的数据,所以我们得先打个表!打表记录每一种情况,然后后面再来用到前面的数据,所以!采取dp[i][j]的方式来记录,注意dp[i][j]只是状态表示,表示n为i的时候j如果是可能的交点数则dp[i][j]=1,否则dp[i][j]=0;这个题自己思考一下很容易的。

最后注意格式,pe了两次,,,唉,输出方法问题啊!


#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
bool dp[21][200]={{0}};
int main()
{for(int i=1;i<21;i++)dp[i][0]=1;int k;for(int i=2;i<21;i++){for(k=1;k<i;k++){for(int j=0;j<200;j++){if(dp[k][j]==1)dp[i][k*(i-k)+j]=1;}}}
/*for(int i=1;i<21;i++){for(int j=0;j<50;j++)
{if(dp[i][j]==1)cout<<j<<' ';// else cout<<' '<<' ';
}cout<<endl;}*/int n;int s[200];while(cin>>n){int m=0;for(int i=0;i<200;i++)if(dp[n][i])s[m++]=i;cout<<s[0];for(int i=1;i<m;i++)cout<<' '<<s[i];cout<<endl;}return 0;
}



转载于:https://www.cnblogs.com/martinue/p/5490516.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/405084.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[react] 你最喜欢React的哪一个特性(说一个就好)

[react] 你最喜欢React的哪一个特性&#xff08;说一个就好&#xff09; virtual domHOC 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

Linux多线程开发-线程同步-读写锁pthread_rwlock_t

1、读写锁概念 对资源的访问抽象为两种类型&#xff0c;即独占和共享。独占资源具有排他性&#xff0c;例如写操作。共享资源可以同时由多个线程访问&#xff0c;不对该资源执行写操作。针对资源的读和写操作分别加锁&#xff0c;写操作加锁与互斥锁相同&#xff0c;但读操作加…

Wireshark抓包工具使用教程以及常用抓包规则

From: http://fangxin.blog.51cto.com/1125131/735178 Wireshark是一个非常好用的抓包工具&#xff0c;当我们遇到一些和网络相关的问题时&#xff0c;可以通过这个工具进行分析&#xff0c;不过要说明的是&#xff0c;这只是一个工具&#xff0c;用法是非常灵活的&#xff0c;…

SSH整合--1

简单说明&#xff1a;整个整合过程使用mysql数据库、Myeclipse 8.5&#xff0c;框架使用struts2.1.6,hibernate3.x,spring2.5 功能&#xff1a;实现简单的用户登录 0. 简单的流程 1. Resister.jsp <% page language"java" import"java.util.*" pageEnco…

[react] 在React中什么时候使用箭头函数更方便呢?

[react] 在React中什么时候使用箭头函数更方便呢&#xff1f; 合成事件当中使用箭头函数比较方便 注意点在于当事件作为props传递给子组件时&#xff0c;会造成额外的性能损耗 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一…

poj3750

简单题 View Code #include <iostream>#include <cstdio>#include <cstdlib>#include <cstring>usingnamespacestd;#definemaxn 100intn, w, s;charname[maxn][100];boolout[maxn];intmain(){//freopen("t.txt", "r", stdin);sca…

Linux多线程开发-线程同步-条件变量pthread_cond_t

1、条件变量的概念 一个线程A的执行需要另一个线程B来唤醒&#xff0c;否则A挂起等待。线程B可以产生线程A继续执行的信号。条件变量常用在共享数据状态变化的场景中&#xff0c;例如&#xff1a;生产则和消费者问题。POSIX线程库提供了条件变量这种同步机制。使用条件变量需要…

FreeSWITCH安装报错“You must install libyuv-dev to build mod_fsv”的解决方案

昨天下午安装FreeSWITCH时遇到该问题时&#xff0c;整了一个下午都没解决&#xff0c;也走了许多弯路。如果直接通过yum安装libyuv-devel时&#xff0c;会报错说找不到该安装包。后来又通过FreeSWITCH官网的网上聊天&#xff0c;找FreeSWITCH的工作人员要到了libyuv-devel的安装…

linux内核模块常见问题

From: http://debug-sai.blogbus.com/logs/45569599.html 一 在编译内核模块时&#xff0c;出现 make[1]: 正在进入目录 /usr/src/linux-2.6.28 ERROR: Kernel configuration is invalid. include/linux/autoconf.h or include/config/auto.conf are missing. …

[react] 使用PropTypes和Flow有什么区别?

[react] 使用PropTypes和Flow有什么区别&#xff1f; Flow 是一个针对react项目所有 JavaScript 代码的静态类型检测器&#xff0c;需要单独添加依赖并手动运行PropTypes是针对组件级别的类型检测 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&am…

EF架构~了解一下,ADO.NET Entity Framework

回到目录 以下文章部分来自百度百科 背景 长久以来&#xff0c;程序设计师和数据库总是保持着一种微妙的关系&#xff0c;在商用应用程序中&#xff0c;数据库一定是不可或缺的元件&#xff0c;这让程序设计师一定要为了连接与访问数据库而去 学习 SQL 指令&#xff0c;因此在信…

如何限制对象只能建立在堆上或者栈上

转自http://blog.csdn.net/szchtx/article/details/12000867# 在C中&#xff0c;类的对象建立分为两种&#xff0c;一种是静态建立&#xff0c;如A a&#xff1b;另一种是动态建立&#xff0c;如A* ptrnew A&#xff1b;这两种方式是有区别的。 静态建立一个类对象&#xff0c;…

Qt主要的容器类

1、描述 容器和迭代器类提供修改、删除、插入、保存数据和遍历等功能&#xff0c;Qt包含的容器类比STL更加简单和安全。 2、常用的容器 QList<T>&#xff1a;使用数据间的索引可以访问数据&#xff0c;储存特定类型。QLinkedList<T>&#xff1a;使用迭代器访问数…

编译我的hello.ko

一、环境&#xff1a; 1. PC: Fedora13: [feng~ #2]$uname -a Linux Fedora13 2.6.34.8-68.fc13.i686.PAE #1 SMP Thu Feb 17 14:54:10 UTC 2011 i686 i686 i386 GNU/Linux [feng~ #3]$2. 开发板 ~ $ uname -a Linux (none) 2.6.24-rt1-hi3515v100 #7 Thu Nov 10 18:42:18 C…

[react] 在React中你有遇到过安全问题吗?怎么解决?

[react] 在React中你有遇到过安全问题吗&#xff1f;怎么解决&#xff1f; dangerouslySetInnerHTML预防xss攻击 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

SQL Server之索引

简单来说&#xff0c;索引就是一个指针&#xff0c;指向表里的数据。创建索引create indext index_name on table_name删除索引drop index index_name on table_name索引的类型单字段索引create indext index_name on table_name&#xff08;column_name&#xff09;如果某个字…

Qt多线程编程的主要线程类

1、描述 Qt提供QThread类处理多线程&#xff0c;继承自QObject。不受平台影响&#xff0c;实现跨平台功能。 2、主要的线程类 QAtomicInt&#xff1a;提供Interger与平台无关的Atomic运算&#xff0c;即提供了整数常用的原子操作&#xff0c;支持四种类型的操作。支持四种类…

安装kernel API的man手册

From: http://blog.163.com/yun_2527/blog/static/3527186120122242516589/ 参考&#xff1a;http://hi.baidu.com/handsoul/blog/item/eb2f59f11d55e8d90a46e0b2.html 系统环境&#xff1a;ubuntu-10.04.1-desktop-i386 1、下载一个内核源代码 2、安装make mandocs的两个依…

绝对不忽悠、暑期择机功能该咋选?

暑期已经过去一半了&#xff0c;但每年的择机高潮却正是个如火如荼&#xff0c;正值暑促阶段&#xff0c;很多手机厂商或商家都会适当的调整价格或者推出更具优惠的方案&#xff0c;吸引买家&#xff0c;其中不乏很多在手机功能上的大肆宣传&#xff0c;我们买手机看重的无外乎…

ASP.NET 5 Beta7发布

&#xff08;此文章同时发表在本人微信公众号“dotNET每日精华文章”&#xff0c;欢迎右边二维码来关注。) 前几天&#xff0c;ASP.NET 5如期发布了Beta 7&#xff0c;根据路线图 (https://github.com/aspnet/home/wiki/roadmap)&#xff0c;这次发布主要是实现跨平台的能力。之…