腾讯笔试题,木棍组成多边形判断

 1 package com.qyz.test;
 2
 3 import java.util.ArrayList;
 4 import java.util.Collections;
 5 import java.util.List;
 6 import java.util.Scanner;
 7
 8 public class Solution {
 9
10     public static void main(String[] args) {
11
12         Scanner s = new Scanner(System.in);
13
14         int n = s.nextInt();
15
16         List<Integer> ls = new ArrayList<Integer>();
17
18         while(n-- > 0){
19             //表示操作类型
20             int o = s.nextInt();
21             //木棍长度
22             int l = s.nextInt();
23             //根据操作对集合增删
24             if(o == 1)
25                 ls.add(l);
26             else if(o == 2)
27                 //注意,remove有两种实现,一种是删除指定位置,一种是删除第一次出现的元素
28                 ls.remove(new Integer(l));
29             else{
30                 System.out.println("ERR!!!");
31                 break;
32             }
33             int len = ls.size();
34             //集合长度小于3不能构成多边形
35             if(len < 3){
36                 System.out.println("No");
37                 continue;
38             }
39             //对集合进行排序,升序
40             Collections.sort(ls);
41             int sum = 0;
42             //计算除最后一个元素(最大元素)的和
43             for(int i = 0;i < len - 1;i++)
44                 sum += ls.get(i);
45
46             if(sum <= ls.get(len-1))
47                 System.out.println("No");
48             else
49                 System.out.println("Yes");
50         }
51         s.close();
52
53     }
54
55 }

该题组要在于对多边形的长度判断,其实很简单,只要有三条线段及以上,且最大边长度小于其余各边的长度和,就可以构成多边形了,添加进list,然后排个序,就可以判断了。

时间: 2024-10-05 23:37:00

腾讯笔试题,木棍组成多边形判断的相关文章

腾讯笔试题:满二叉排序树,任给3个子节点,找他们最大的公共父节点

腾讯笔试题出现了和这个类似的题目,没做出来,现在来好好解决这个问题吧,先从基本的开始. 先吐槽一下:感觉算法设计什么的,真的超级难,也许是我头脑太笨,转不过弯来吧,呵呵. 题目是这样的:一棵满二叉排序树,有K层,节点的值依次为 1~2k-1.现在告诉你树的高度是4层,给定你3个节点,比如9,11, 13,那么最大的公共父节点是12. 现在想起来这题我已经想出来一半了呀,但是大概人在紧张的时候大脑会思维短路,跳不出原有的思维陷阱.想法是这样的: 1. 首先是从根节点开始,如果给的三个叶节点的值其中

多线程关于腾讯笔试题

今天在头条上看到一道据说是腾讯的笔试题,闲来无事,准备验证一下! 题目如下: 有一个变量int a=0:两个线程同时进行+1操作,每个线程加100次,不加锁,最后a的值是()? 根据我的理解答案不唯一,最大是两百,最小是2吧.直接上代码: class MyThread implements Runnable { static volatile long i = 0; public void run() { for (int m = 0; m < 100; m++) { i++; } } }; p

腾讯笔试题----格雷码的实现

昨天腾讯C++研发的一道笔试题,给定一个N,求这N位的格雷码,如果不知道格雷码的请自行问度娘.由于当时答题时间比较紧,所以没有考虑清楚到底该怎么做,只是有一个大体的思路,但是还是没有写上去(感觉自己解决问题的能力还是弱啊.....). 题目已经提示,使用递归求解,既然是递归,我当时想应该利用分治法求解,先设置一位,然后问题的规模就变成N-1,然后再求解,又联想到剑指offer的第12题(打印1到最大的n位数),所以感觉这种思路应该是可以求解的,但是还有一个问题有待解决--怎么满足格雷码的要求(每

C++腾讯笔试题

#include <iostream> using namespace std; //产生任意范围的随机数. int Grial(int i,int j ) { int x = 0; while (!(x>=i && x<j)) { x = rand() % j; } return x; } int main() { cout << Grial(4, 100) << endl; return 0; } #include <iostrea

Linux fork函数详细图解-同时分析一道腾讯笔试题

原创blog,转载请注明出处 头文件: #include<unistd.h> #include<sys/types.h> 函数原型: pid_t fork( void); (pid_t 是一个宏定义,其实质是int 被定义在#include<sys/types.h>中) 返回值: 若成功调用一次则返回两个值,子进程返回0,父进程返回子进程ID:否则,出错返回-1 注意,子进程是父进程的副本,拷贝父进程的数据空间,堆栈等资源.父子进程不共享上述资源. 每执行一次fork(

腾讯笔试题---最长回文字符串

#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int maxn = 10001; char s1[maxn], s2[maxn]; int dp[maxn][maxn]; int count(char* s1, char* s2) { int len1 = strlen(s1); int len2 = s

腾讯笔试题——腾讯2015春招pc客户端开发练习卷

1. C++题目 静态成员函数(类方法) 下列说法错误的有( ) 正确答案: A C D   你的答案: C D (错误) 在类方法中可用this来调用本类的类方法 在类方法中调用本类的类方法时可直接调用 在类方法中只能调用本类中的类方法 在类方法中绝对不能调用实例方法 解析: 成员方法又称为实例方法 静态方法又称为类方法 其次: a,静态方法中没有this指针 c,可以通过类名作用域的方式调用Class::fun(); d,太绝对化了,在类中申请一个类对象或者参数传递一个对象或者指针都可以调用

腾讯笔试题——腾讯研发工程师B笔试卷

1. C,C++程序内存区 2. IP地址分类: 3.计算机网络知识: 浏览器访问某页面,HTTP协议返回状态码为403时表示:禁止访问 浏览器访问某页面,HTTP协议返回状态码为404时表示:找不到该页面 浏览器访问某页面,HTTP协议返回状态码为500时表示:内部服务器访问 浏览器访问某页面,HTTP协议返回状态码为503时表示:服务器繁忙 4. C++,类的构造 当派生类中不含对象成员时 · 在创建派生类对象时,构造函数的执行顺序是:基类的构造函数→派生类的构造函数: · 在撤消派生类对象

腾讯笔试题

1 #include <iostream> 2 3 using namespace std; 4 void hello(int a ,int b=7,char* pszC="*") 5 { 6 cout<<"hello"; 7 } 8 9 int main() 10 { 11 // hello(5); 12 // hello(5,8); 13 hello(6,"#"); //报错 14 //hello(0,0,"