- 浏览: 468083 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
ty1972873004:
sunwang810812 写道我运行了这个例子,怎么结果是这 ...
Java并发编程: 使用Semaphore限制资源并发访问的线程数 -
lgh1992314:
simpleDean 写道请问,Logger.setLevel ...
Java内置Logger详解 -
sunwang810812:
我运行了这个例子,怎么结果是这样的:2号车泊车6号车泊车5号车 ...
Java并发编程: 使用Semaphore限制资源并发访问的线程数 -
jp260715007:
nanjiwubing123 写道参考你的用法,用如下方式实现 ...
面试题--三个线程循环打印ABC10次的几种解决方法 -
cb_0312:
SurnameDictionary文章我没看完,现在懂了
中文排序
逛网页的时候,发现阿里巴巴2014校园招聘笔试最后一道题目
http://blog.csdn.net/qingsong3333/article/details/11910771
题目:在黑板上写下50个数字:1至50.在接下来的49轮操作中,每次做如下动作:选取两个黑板上的数字a和b,擦去,在黑板上写|b - a|。请问最后一次动作之后剩下数字可能是什么?为什么?
我的分析:由于擦除数字的随机性,最后一定不是某个具体的数字,唯独能确定的是奇数还是偶数。
我的答案:最后是个奇数,原因如下:
首先对可能擦除的种类进行分析,有三种可能:
1. 擦除两个奇数 Num1 和Num2, 擦除后新增一个偶数 Num3 = |Num1 - Num2|
在这种情况下 Num1 + Num2 - |Num1 - Num2| 是偶数,也就是说,这种情况下,黑板上现有数字的总和会减少一个偶数值( Num1 + Num2 - |Num1 - Num2| )
2. 擦除两个偶数Num1 和 Num2, 擦除后新增一个偶数Num3 = |Num1 -Num2|
在这种情况下 Num1 + Num2 - |Num1 - Num2| 是偶数,也就是说,这种情况下,黑板上现有数字的总和会减少一个偶数值( Num1 + Num2 - |Num1 - Num2| )
3. 擦除一个偶数(Num1)一个奇数(Num2), 擦除后新增一个奇数Num3 = |Num1 - num2|, 在这种情况下 Num1 + Num2 - |Num1 - Num2| 还是一个偶数,也就是说,这种情况下,黑板上现有数字的总和会减少一个偶数值( Num1 + Num2 - |Num1 - Num2| )
上述三种可能的情况可以看出,不管是哪一种情况,每次操作都将减少一个偶数差值。(Num1 + Num2 - |Num1 - Num2|)
这样,最后剩余的一个数是奇数还是偶数,我们只要看一下1到50的总和是奇数还是偶数即可。
1到50的和是1275,是一个奇数,这样我们便可以知道最后一个数一定是一个奇数,因为每次擦除操作减少的都是一个偶数差值(Num1 + Num2 - |Num1 - Num2|)。
下面用程序来运行一下,也能发现最后的数字是一个奇数。
程序如下:
某次运行的结果:
第1次运行,最后剩余的数是--> 13, 是个奇数
第2次运行,最后剩余的数是--> 9, 是个奇数
第3次运行,最后剩余的数是--> 13, 是个奇数
第4次运行,最后剩余的数是--> 27, 是个奇数
第5次运行,最后剩余的数是--> 1, 是个奇数
第6次运行,最后剩余的数是--> 7, 是个奇数
第7次运行,最后剩余的数是--> 7, 是个奇数
第8次运行,最后剩余的数是--> 3, 是个奇数
第9次运行,最后剩余的数是--> 13, 是个奇数
第10次运行,最后剩余的数是--> 11, 是个奇数
第11次运行,最后剩余的数是--> 1, 是个奇数
第12次运行,最后剩余的数是--> 15, 是个奇数
第13次运行,最后剩余的数是--> 13, 是个奇数
第14次运行,最后剩余的数是--> 17, 是个奇数
第15次运行,最后剩余的数是--> 1, 是个奇数
第16次运行,最后剩余的数是--> 7, 是个奇数
第17次运行,最后剩余的数是--> 15, 是个奇数
第18次运行,最后剩余的数是--> 21, 是个奇数
第19次运行,最后剩余的数是--> 7, 是个奇数
第20次运行,最后剩余的数是--> 11, 是个奇数
第21次运行,最后剩余的数是--> 1, 是个奇数
第22次运行,最后剩余的数是--> 1, 是个奇数
第23次运行,最后剩余的数是--> 19, 是个奇数
第24次运行,最后剩余的数是--> 17, 是个奇数
第25次运行,最后剩余的数是--> 9, 是个奇数
第26次运行,最后剩余的数是--> 15, 是个奇数
第27次运行,最后剩余的数是--> 9, 是个奇数
第28次运行,最后剩余的数是--> 7, 是个奇数
第29次运行,最后剩余的数是--> 23, 是个奇数
第30次运行,最后剩余的数是--> 17, 是个奇数
第31次运行,最后剩余的数是--> 13, 是个奇数
第32次运行,最后剩余的数是--> 27, 是个奇数
第33次运行,最后剩余的数是--> 15, 是个奇数
第34次运行,最后剩余的数是--> 11, 是个奇数
第35次运行,最后剩余的数是--> 21, 是个奇数
第36次运行,最后剩余的数是--> 9, 是个奇数
第37次运行,最后剩余的数是--> 11, 是个奇数
第38次运行,最后剩余的数是--> 7, 是个奇数
第39次运行,最后剩余的数是--> 3, 是个奇数
第40次运行,最后剩余的数是--> 11, 是个奇数
第41次运行,最后剩余的数是--> 9, 是个奇数
第42次运行,最后剩余的数是--> 11, 是个奇数
第43次运行,最后剩余的数是--> 23, 是个奇数
第44次运行,最后剩余的数是--> 7, 是个奇数
第45次运行,最后剩余的数是--> 5, 是个奇数
第46次运行,最后剩余的数是--> 11, 是个奇数
第47次运行,最后剩余的数是--> 25, 是个奇数
第48次运行,最后剩余的数是--> 29, 是个奇数
第49次运行,最后剩余的数是--> 15, 是个奇数
第50次运行,最后剩余的数是--> 3, 是个奇数
第51次运行,最后剩余的数是--> 9, 是个奇数
第52次运行,最后剩余的数是--> 5, 是个奇数
第53次运行,最后剩余的数是--> 1, 是个奇数
第54次运行,最后剩余的数是--> 21, 是个奇数
第55次运行,最后剩余的数是--> 1, 是个奇数
第56次运行,最后剩余的数是--> 33, 是个奇数
第57次运行,最后剩余的数是--> 9, 是个奇数
第58次运行,最后剩余的数是--> 15, 是个奇数
第59次运行,最后剩余的数是--> 1, 是个奇数
第60次运行,最后剩余的数是--> 5, 是个奇数
第61次运行,最后剩余的数是--> 3, 是个奇数
第62次运行,最后剩余的数是--> 29, 是个奇数
第63次运行,最后剩余的数是--> 11, 是个奇数
第64次运行,最后剩余的数是--> 13, 是个奇数
第65次运行,最后剩余的数是--> 3, 是个奇数
第66次运行,最后剩余的数是--> 5, 是个奇数
第67次运行,最后剩余的数是--> 9, 是个奇数
第68次运行,最后剩余的数是--> 7, 是个奇数
第69次运行,最后剩余的数是--> 7, 是个奇数
第70次运行,最后剩余的数是--> 19, 是个奇数
第71次运行,最后剩余的数是--> 7, 是个奇数
第72次运行,最后剩余的数是--> 25, 是个奇数
第73次运行,最后剩余的数是--> 1, 是个奇数
第74次运行,最后剩余的数是--> 3, 是个奇数
第75次运行,最后剩余的数是--> 5, 是个奇数
第76次运行,最后剩余的数是--> 13, 是个奇数
第77次运行,最后剩余的数是--> 15, 是个奇数
第78次运行,最后剩余的数是--> 15, 是个奇数
第79次运行,最后剩余的数是--> 9, 是个奇数
第80次运行,最后剩余的数是--> 15, 是个奇数
第81次运行,最后剩余的数是--> 19, 是个奇数
第82次运行,最后剩余的数是--> 3, 是个奇数
第83次运行,最后剩余的数是--> 7, 是个奇数
第84次运行,最后剩余的数是--> 3, 是个奇数
第85次运行,最后剩余的数是--> 15, 是个奇数
第86次运行,最后剩余的数是--> 13, 是个奇数
第87次运行,最后剩余的数是--> 5, 是个奇数
第88次运行,最后剩余的数是--> 9, 是个奇数
第89次运行,最后剩余的数是--> 3, 是个奇数
第90次运行,最后剩余的数是--> 29, 是个奇数
第91次运行,最后剩余的数是--> 5, 是个奇数
第92次运行,最后剩余的数是--> 11, 是个奇数
第93次运行,最后剩余的数是--> 15, 是个奇数
第94次运行,最后剩余的数是--> 15, 是个奇数
第95次运行,最后剩余的数是--> 5, 是个奇数
第96次运行,最后剩余的数是--> 31, 是个奇数
第97次运行,最后剩余的数是--> 5, 是个奇数
第98次运行,最后剩余的数是--> 1, 是个奇数
第99次运行,最后剩余的数是--> 9, 是个奇数
第100次运行,最后剩余的数是--> 23, 是个奇数
转载请注明出处:http://mouselearnjava.iteye.com/blog/1949605
http://blog.csdn.net/qingsong3333/article/details/11910771
题目:在黑板上写下50个数字:1至50.在接下来的49轮操作中,每次做如下动作:选取两个黑板上的数字a和b,擦去,在黑板上写|b - a|。请问最后一次动作之后剩下数字可能是什么?为什么?
我的分析:由于擦除数字的随机性,最后一定不是某个具体的数字,唯独能确定的是奇数还是偶数。
我的答案:最后是个奇数,原因如下:
首先对可能擦除的种类进行分析,有三种可能:
1. 擦除两个奇数 Num1 和Num2, 擦除后新增一个偶数 Num3 = |Num1 - Num2|
在这种情况下 Num1 + Num2 - |Num1 - Num2| 是偶数,也就是说,这种情况下,黑板上现有数字的总和会减少一个偶数值( Num1 + Num2 - |Num1 - Num2| )
2. 擦除两个偶数Num1 和 Num2, 擦除后新增一个偶数Num3 = |Num1 -Num2|
在这种情况下 Num1 + Num2 - |Num1 - Num2| 是偶数,也就是说,这种情况下,黑板上现有数字的总和会减少一个偶数值( Num1 + Num2 - |Num1 - Num2| )
3. 擦除一个偶数(Num1)一个奇数(Num2), 擦除后新增一个奇数Num3 = |Num1 - num2|, 在这种情况下 Num1 + Num2 - |Num1 - Num2| 还是一个偶数,也就是说,这种情况下,黑板上现有数字的总和会减少一个偶数值( Num1 + Num2 - |Num1 - Num2| )
上述三种可能的情况可以看出,不管是哪一种情况,每次操作都将减少一个偶数差值。(Num1 + Num2 - |Num1 - Num2|)
这样,最后剩余的一个数是奇数还是偶数,我们只要看一下1到50的总和是奇数还是偶数即可。
1到50的和是1275,是一个奇数,这样我们便可以知道最后一个数一定是一个奇数,因为每次擦除操作减少的都是一个偶数差值(Num1 + Num2 - |Num1 - Num2|)。
下面用程序来运行一下,也能发现最后的数字是一个奇数。
程序如下:
package my.thread; import java.util.LinkedList; import java.util.List; import java.util.Random; /** * * @author Eric * */ public class AlibabaExample { public static void main(String[] args) { AlibabaExample example = new AlibabaExample(); int lastIntValue = 0; for (int i = 0; i < 100; i++) { lastIntValue = example.populateLastRemainingNumber(); System.out.println(String.format("第%d次运行,最后剩余的数是--> %d, 是个%s", i + 1, lastIntValue, lastIntValue % 2 == 0 ? "偶数" : "奇数")); } } public int populateLastRemainingNumber() { List<Integer> intList = initList(); Random ran = new Random(); int size = 0; int ranIndex1 = 0; int ranIndex2 = 0; int num1 = 0; int num2 = 0; for (int i = 0; i < 49; i++) { size = intList.size(); ranIndex1 = ran.nextInt(size); while (true) { ranIndex2 = ran.nextInt(size); if (ranIndex1 != ranIndex2) { break; } } num1 = intList.get(ranIndex1); num2 = intList.get(ranIndex2); intList.remove(ranIndex1); if (ranIndex1 > ranIndex2) { intList.remove(ranIndex2); } else { intList.remove(ranIndex2 - 1); } intList.add(Math.abs(num1 - num2)); } return intList.get(0); } private List<Integer> initList() { List<Integer> intList = new LinkedList<Integer>(); for (int i = 1; i < 51; i++) { intList.add(i); } return intList; } }
某次运行的结果:
第1次运行,最后剩余的数是--> 13, 是个奇数
第2次运行,最后剩余的数是--> 9, 是个奇数
第3次运行,最后剩余的数是--> 13, 是个奇数
第4次运行,最后剩余的数是--> 27, 是个奇数
第5次运行,最后剩余的数是--> 1, 是个奇数
第6次运行,最后剩余的数是--> 7, 是个奇数
第7次运行,最后剩余的数是--> 7, 是个奇数
第8次运行,最后剩余的数是--> 3, 是个奇数
第9次运行,最后剩余的数是--> 13, 是个奇数
第10次运行,最后剩余的数是--> 11, 是个奇数
第11次运行,最后剩余的数是--> 1, 是个奇数
第12次运行,最后剩余的数是--> 15, 是个奇数
第13次运行,最后剩余的数是--> 13, 是个奇数
第14次运行,最后剩余的数是--> 17, 是个奇数
第15次运行,最后剩余的数是--> 1, 是个奇数
第16次运行,最后剩余的数是--> 7, 是个奇数
第17次运行,最后剩余的数是--> 15, 是个奇数
第18次运行,最后剩余的数是--> 21, 是个奇数
第19次运行,最后剩余的数是--> 7, 是个奇数
第20次运行,最后剩余的数是--> 11, 是个奇数
第21次运行,最后剩余的数是--> 1, 是个奇数
第22次运行,最后剩余的数是--> 1, 是个奇数
第23次运行,最后剩余的数是--> 19, 是个奇数
第24次运行,最后剩余的数是--> 17, 是个奇数
第25次运行,最后剩余的数是--> 9, 是个奇数
第26次运行,最后剩余的数是--> 15, 是个奇数
第27次运行,最后剩余的数是--> 9, 是个奇数
第28次运行,最后剩余的数是--> 7, 是个奇数
第29次运行,最后剩余的数是--> 23, 是个奇数
第30次运行,最后剩余的数是--> 17, 是个奇数
第31次运行,最后剩余的数是--> 13, 是个奇数
第32次运行,最后剩余的数是--> 27, 是个奇数
第33次运行,最后剩余的数是--> 15, 是个奇数
第34次运行,最后剩余的数是--> 11, 是个奇数
第35次运行,最后剩余的数是--> 21, 是个奇数
第36次运行,最后剩余的数是--> 9, 是个奇数
第37次运行,最后剩余的数是--> 11, 是个奇数
第38次运行,最后剩余的数是--> 7, 是个奇数
第39次运行,最后剩余的数是--> 3, 是个奇数
第40次运行,最后剩余的数是--> 11, 是个奇数
第41次运行,最后剩余的数是--> 9, 是个奇数
第42次运行,最后剩余的数是--> 11, 是个奇数
第43次运行,最后剩余的数是--> 23, 是个奇数
第44次运行,最后剩余的数是--> 7, 是个奇数
第45次运行,最后剩余的数是--> 5, 是个奇数
第46次运行,最后剩余的数是--> 11, 是个奇数
第47次运行,最后剩余的数是--> 25, 是个奇数
第48次运行,最后剩余的数是--> 29, 是个奇数
第49次运行,最后剩余的数是--> 15, 是个奇数
第50次运行,最后剩余的数是--> 3, 是个奇数
第51次运行,最后剩余的数是--> 9, 是个奇数
第52次运行,最后剩余的数是--> 5, 是个奇数
第53次运行,最后剩余的数是--> 1, 是个奇数
第54次运行,最后剩余的数是--> 21, 是个奇数
第55次运行,最后剩余的数是--> 1, 是个奇数
第56次运行,最后剩余的数是--> 33, 是个奇数
第57次运行,最后剩余的数是--> 9, 是个奇数
第58次运行,最后剩余的数是--> 15, 是个奇数
第59次运行,最后剩余的数是--> 1, 是个奇数
第60次运行,最后剩余的数是--> 5, 是个奇数
第61次运行,最后剩余的数是--> 3, 是个奇数
第62次运行,最后剩余的数是--> 29, 是个奇数
第63次运行,最后剩余的数是--> 11, 是个奇数
第64次运行,最后剩余的数是--> 13, 是个奇数
第65次运行,最后剩余的数是--> 3, 是个奇数
第66次运行,最后剩余的数是--> 5, 是个奇数
第67次运行,最后剩余的数是--> 9, 是个奇数
第68次运行,最后剩余的数是--> 7, 是个奇数
第69次运行,最后剩余的数是--> 7, 是个奇数
第70次运行,最后剩余的数是--> 19, 是个奇数
第71次运行,最后剩余的数是--> 7, 是个奇数
第72次运行,最后剩余的数是--> 25, 是个奇数
第73次运行,最后剩余的数是--> 1, 是个奇数
第74次运行,最后剩余的数是--> 3, 是个奇数
第75次运行,最后剩余的数是--> 5, 是个奇数
第76次运行,最后剩余的数是--> 13, 是个奇数
第77次运行,最后剩余的数是--> 15, 是个奇数
第78次运行,最后剩余的数是--> 15, 是个奇数
第79次运行,最后剩余的数是--> 9, 是个奇数
第80次运行,最后剩余的数是--> 15, 是个奇数
第81次运行,最后剩余的数是--> 19, 是个奇数
第82次运行,最后剩余的数是--> 3, 是个奇数
第83次运行,最后剩余的数是--> 7, 是个奇数
第84次运行,最后剩余的数是--> 3, 是个奇数
第85次运行,最后剩余的数是--> 15, 是个奇数
第86次运行,最后剩余的数是--> 13, 是个奇数
第87次运行,最后剩余的数是--> 5, 是个奇数
第88次运行,最后剩余的数是--> 9, 是个奇数
第89次运行,最后剩余的数是--> 3, 是个奇数
第90次运行,最后剩余的数是--> 29, 是个奇数
第91次运行,最后剩余的数是--> 5, 是个奇数
第92次运行,最后剩余的数是--> 11, 是个奇数
第93次运行,最后剩余的数是--> 15, 是个奇数
第94次运行,最后剩余的数是--> 15, 是个奇数
第95次运行,最后剩余的数是--> 5, 是个奇数
第96次运行,最后剩余的数是--> 31, 是个奇数
第97次运行,最后剩余的数是--> 5, 是个奇数
第98次运行,最后剩余的数是--> 1, 是个奇数
第99次运行,最后剩余的数是--> 9, 是个奇数
第100次运行,最后剩余的数是--> 23, 是个奇数
转载请注明出处:http://mouselearnjava.iteye.com/blog/1949605
发表评论
-
工厂类中移除if/else语句
2016-07-10 19:52 911面向对象语言的一个强大的特性是多态,它可以用来在代码中移除 ... -
Java编程练手100题
2014-12-11 17:13 6736本文给出100道Java编程练手的程序。 列表如下: 面 ... -
数组复制的三种方法
2014-11-30 12:57 2232本文将给出三种实现数组复制的方法 (以复制整数数组为例)。 ... -
数组复制的三种方法
2014-11-30 12:54 0本文将给出三种实现数组复制的方法 (以复制整数数组为例)。 ... -
四种复制文件的方法
2014-11-29 13:21 1749尽管Java提供了一个类ava.io.File用于文件的操 ... -
判断一个字符串中的字符是否都只出现一次
2014-11-25 12:58 2749本篇博文将给大家带来几个判断一个字符串中的字符是否都只出现一 ... -
使用正则表达式判断一个数是否为素数
2014-11-23 13:35 2177正则表达式能够用于判断一个数是否为素数,这个以前完全没有想过 ... -
几个可以用英文单词表达的正则表达式
2014-11-21 13:12 3766本文,我们将来看一下几个可以用英文单词表达的正则表达式。这些 ... -
(广度优先搜索)打印所有可能的括号组合
2014-11-20 11:58 1966问题:给定一个正整n,作为括号的对数,输出所有括号可能 ... -
随机产生由特殊字符,大小写字母以及数字组成的字符串,且每种字符都至少出现一次
2014-11-19 14:48 3988题目:随机产生字符串,字符串中的字符只能由特殊字符 (! ... -
找出1到n缺失的一个数
2014-11-18 12:57 3195题目:Problem description: You h ... -
EnumSet的几个例子
2014-11-14 16:24 8764EnumSet 是一个与枚举类型一起使用的专用 Set 实现 ... -
给定两个有序数组和一个指定的sum值,从两个数组中各找一个数使得这两个数的和与指定的sum值相差最小
2014-11-12 11:24 3338题目:给定两个有序数组和一个指定的sum值,从两个数组 ... -
Java面试编程题练手
2014-11-04 22:49 6711面试编程 写一个程序,去除有序数组中的重复数字 编 ... -
Collections用法整理
2014-10-22 20:55 9855Collections (java.util.Collect ... -
The Code Sample 代码实例 个人博客开通
2014-09-04 18:48 1429个人博客小站开通 http://thecodesample. ... -
Collections.emptyXXX方法
2014-06-08 13:37 2152从JDK 1.5开始, Collections集合工具类中预先 ... -
这代码怎么就打印出"hello world"了呢?
2014-06-08 00:37 7402for (long l = 4946144450195624L ... -
最短时间过桥
2014-04-21 22:03 4170本文用代码实现最短时间过桥,并且打印如下两个例子的最小过桥时间 ... -
将数组分割成差值最小的子集
2014-04-20 22:34 2911本文使用位掩码实现一个功能 ==》将数组分割成差值最小的子集 ...
相关推荐
- **答案**: A、两个或两个以上的函数取相同的函数名,但形参的个数或类型不同 **解析**: - 函数重载允许在同一个类中定义多个同名方法,但这些方法的参数列表必须有所不同。 ### 16、异常处理 **题目**: 在异常...
【Python数据分析面试题汇总】 1. **Python求和**:Python内置函数`sum()`可用于求和,例如`sum(range(1, 101))`将计算从1到100的所有数字的总和。 2. **全局变量修改**:在函数内部修改全局变量需使用`global`...
ng new) 用新字符串替换旧字符串 split(String regex) 使用正则表达式分割字符串 trim() 去掉字符串两端的空白符 Java 面试题涵盖了诸多核心概念,包括但不限于: 1. **JDK 与 JRE**:JDK 是 Java 开发工具包,...
根据给定的信息,我们可以深入探讨这道华为面试题——“两个长数字相乘”的实现细节与背后的算法原理。 ### 题目解析 题目要求计算两个长整数相乘的结果,这里的“长整数”指的是那些无法直接用现有的数据类型(如...
C++面试题 1.是不是一个父类写了一个virtual 函数,如果子类覆盖它的函数不加virtual ,也能实现多态? virtual修饰符会被隐形继承的。 private 也被集成,只事派生类没有访问权限而已 virtual可加可不加 子类的...
前端大厂最新面试题-algorithm.docx 本文档涵盖了前端工程师面试中涉及到的算法问题,共90个题目,涵盖了字符串、数组、链表、栈、队列、树、排序、搜索、加密等多方面的知识点。 字符串部分 1. 封装一个函数,能...
本文将深入探讨一个常见的面试题:字符串反转。题目中给出的代码实现了一个递归方法`reverseString`来完成这一任务。下面我们将详细解析这个函数以及相关知识点。 首先,让我们分析`reverseString`函数的工作原理:...
【MySQL面试题解析】 MySQL是世界上最流行的关系型数据库管理系统之一,尤其在Web开发领域中广泛应用。以下是一些MySQL面试中的常见问题及其详细解答: 1. 数据库是什么? 数据库是一个用于存储和管理数据的系统...
### Java工程师面试题知识点解析 #### 一、Hibernate中离线查询去除重复项 - **问题**: Hibernate中如何在离线查询中去除重复项? - **解决方案**: 在Hibernate的Criteria API中,可以通过调用`...
前端大厂最新面试题-css CSS是前端开发的基础,以下是对前端大厂最新面试题-css的总结和解释。 1. 控制元素的盒模型的属性是box-sizing。 2. 相邻选择器是+,能匹配相邻的兄弟元素。 3. 不能被子元素继承的属性...
### 数据库常见面试题解析 #### 1、数据库有哪几种范式? 数据库设计中遵循的规范称为“范式”,目前主要有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、BCNF(Boyce-Codd范式)、第四范式(4NF...
在第三道面试题中,一个子查询使用了 `union all` 来合并两个表中的商品ID,然后计算每个ID在两个表中出现的次数。 3. **聚合函数** - `count()`, `sum()` 等聚合函数在统计和分析数据时非常有用。第二道面试题中...
《星辰里的月光Java面试题-最新整理》 在Java面试中,掌握核心知识点是至关重要的。这份文档整理了一些常见的Java面试题,涵盖了JavaSE的基础编程、面向对象特性、注释定义、关键字用法以及一些类和方法的理解。...
### 50个C、C++面试题及50个智力测试题——经典智力测试题解析 #### 面试题1:斯密斯夫妇握手问题 **题目背景**: 斯密斯夫妇邀请了另外四对夫妇共进晚餐。在聚会过程中,每个人都遵循了一些规则:不与自己或配偶...
在面试题三中,`INTERSECT`用于找到商品A和B在两个表中都存在的ID。 4. **聚合函数与分组**: - `COUNT()`, `SUM()`, `GROUP BY`等用于统计和分组数据。面试题三中,使用`COUNT()`统计每个文化程度和年龄的人数,`...
6. **最大公约数和最小公倍数**:使用辗转相除法(欧几里得算法)可以求得两个数的最大公约数,最小公倍数可以通过两数相乘除以最大公约数得到。 7. **字符统计**:通过while循环,逐个读取字符,用条件判断统计...
用这个数依次去除2到sqrt(这个数),如果期间没有能被整除的数,则这个数为素数。 - 由于我们只需要判断101到200之间的素数,所以循环的范围非常有限,可直接遍历此范围内的每个数,用试除法进行判断。 #### 程序3:...