热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

hlg_oj_1116_选美大赛

hlg_oj_1116_选美大赛这题是最长子序列,然后再求出路径就可以了。开始写的比较乱,用数组什么的,后来用了指针就好办了。现在把代码贴
hlg_oj_1116_选美大赛

这题是最长子序列,然后再求出路径就可以了。开始写的比较乱,用数组什么的,后来用了指针就好办了。现在把代码贴出来。指针真的挺给力的。

--------------------------------------------------------------------------------------------------------------------

1 #include
2 #include
3 #include
4 using namespace std;
5 struct people
6 {
7 int num,h;
8 people* last;
9 }girl[100+5];
10 int main()
11 {
12 int n;
13 int i,j;
14 int dp[100+10];
15 stack<int>haha;
16 while(cin>>n&&n)
17 {
18 for(i&#61;1;i<&#61;n;&#43;&#43;i)
19 dp[i]&#61;1;
20 for(i&#61;1;i<&#61;n;&#43;&#43;i)
21 {
22 cin>>girl[i].h;
23 girl[i].num&#61;i;
24 girl[i].last&#61;NULL;
25 }
26 for(i&#61;1;i<&#61;n;&#43;&#43;i)
27 {
28 for(j&#61;1;jj)
29 {
30 if(girl[i].h>girl[j].h)
31 {
32 if(dp[j]&#43;1>dp[i])
33 {
34 dp[i]&#61;dp[j]&#43;1;
35 girl[i].last&#61;&girl[j];
36
37 }
38 }
39 }
40 }
41 int max&#61;0,maxsign&#61;0;
42 for(i&#61;1;i<&#61;n;&#43;&#43;i)
43 {
44 if(dp[i]>max){ max&#61;dp[i];maxsign&#61;i;}
45 }
46 cout<<"The number is ";
47 cout<<max;
48 cout<<":";
49 haha.push(girl[maxsign].num);
50 people* temple&#61;girl[maxsign].last;
51 while(temple)
52 {
53 haha.push(temple->num);
54 temple&#61;temple->last;
55 }
56 while(haha.size()>0)
57 {
58 cout<<" "<<haha.top();haha.pop();}
59 cout<<endl;
60 }
61 return 0;
62 }
63
64
65
66
67

 

posted on 2012-11-18 17:30 symons 阅读(...) 评论(...) 编辑 收藏

转:https://www.cnblogs.com/symons1992/archive/2012/11/18/2776120.html



推荐阅读
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • C++: 实现基于类的四面体体积计算
    本文介绍如何使用C++编程语言,通过定义类和方法来计算由四个三维坐标点构成的四面体体积。文中详细解释了四面体体积的数学公式,并提供了两种不同的实现方式。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
author-avatar
手机用户2602925213
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有