博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[华为机试练习题]37.合唱队
阅读量:6689 次
发布时间:2019-06-25

本文共 2613 字,大约阅读时间需要 8 分钟。

题目

描写叙述:

计算最少出列多少位同学。使得剩下的同学排成合唱队形说明:N位同学站成一排,音乐老师要请当中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形。

合唱队形是指这种一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK, 则他们的身高满足存在i(1<=i<=K)使得T1 < T2 <...... < Ti-1 < Ti >Ti+1 >......>TK。 你的任务是。已知全部N位同学的身高。计算最少须要几位同学出列,能够使得剩下的同学排成合唱队形。

题目类别:

循环

难度:

0基础

执行时间限制:

无限制

内存限制:

无限制

阶段:

入职前练习

输入:

整数N一行整数,空格隔开,N位同学身高

输出:

最少须要几位同学出列

例子输入:

8186 186 150 200 160 130 197 200

例子输出:

4

代码

/*---------------------------------------*   日期:2015-07-02*   作者:SJF0115*   题目:合唱队*   来源:华为机试练习题-----------------------------------------*/#include 
#include
#include
#include
#include
using namespace std;int Chorus(vector
height){ int n = height.size(); if(n == 0){ return 0; }//if // left to right left[i] 统计出左边小于height[i]的身高个数(left[i] 包含height[i]本身) vector
left(n,1); for(int i = 1;i < n;++i){ for(int j = i-1;j >=0;--j){ if(height[i] > height[j]){ if(left[i] < left[j]+1){ left[i] = left[j]+1; }//if }//if }//for }//for // right to left right[i] 统计出右边小于height[i]的身高个数(right[i] 包含height[i]本身) vector
right(n,1); for(int i = n-2;i >= 0;--i){ for(int j = i+1;j < n;++j){ if(height[i] > height[j]){ if(right[i] < right[j]+1){ right[i] = right[j]+1; }//if }//if }//for }//for int max = 0; for(int i = 0;i < n;++i){ if(max < left[i] + right[i] - 1){ max = left[i] + right[i] - 1; }//if }//for return n - max;}int main(){ int n; //freopen("C:\\Users\\Administrator\\Desktop\\c++.txt","r",stdin); while(cin>>n){ vector
height; int h; // 输入身高 for(int i = 0;i < n;++i){ cin>>h; height.push_back(h); }//for cout<
<
#include 
#include
using namespace std;int solve(int n);int main(){ int n; //freopen("C:\\Users\\Administrator\\Desktop\\c++.txt","r",stdin); while(cin>>n){ cout << solve(n) << endl; } return 0;}int solve(int n){ if(n==0 || n==1) return 0; int res = 0,h=0; vector
height; for(int i=0;i
> h; height.push_back(h); } vector
left(n,1), right(n,1); for(int i=0;i
height[j]) if(left[i]
< n;++k){ if(height[n-i-1]>height[k]) if(right[n-i-1]
< n;++i){ cout<
<<" "; } cout<
< n;++i){ cout<
<<" "; } cout<

转载于:https://www.cnblogs.com/yutingliuyl/p/7059452.html

你可能感兴趣的文章
Android错误threadid=1: thread exiting with uncaught
查看>>
scheme 初探
查看>>
asdf
查看>>
Spring MVC之@RequestParam @RequestBody @RequestHead
查看>>
恒星内部的虫洞
查看>>
LaTeX特殊字符
查看>>
Golang 错误和异常处理的正确姿势
查看>>
JXL的api的简单介绍
查看>>
好久不写文章了
查看>>
声明和定义的区别(深入理解)
查看>>
java连接oracle小小demo
查看>>
分布式系统测试那些事儿——错误注入
查看>>
android-------非常好的图片加载框架和缓存库(Picasso)
查看>>
Titanium, PhoneGap, Sencha Touch, jQuery Mobile – Clearing up confusion
查看>>
eclipse如何部署Web工程到tomcat中
查看>>
在CentOS7上安装JDK1.8
查看>>
搜索和网页排名的数学原理
查看>>
Xcode项目中同一个名称不同位置 简单修改
查看>>
java设计模式-建造者模式
查看>>
Android Shell 快捷键
查看>>