目录

1 年龄巧合

2 出栈次序

3 信号匹配

4 生物芯片

5 Log大侠

6 殖民地

 

前言:以下代码仅供参考,若有错误欢迎指正哦~


1 年龄巧合

  1. 小明和他的表弟一起去看电影,有人问他们的年龄。小明说:今年是我们的幸运年啊。我出生年份的四位数字加起来刚好是我的年龄。表弟的也是如此。已知今年是2014年,并且,小明说的年龄指的是周岁。
  2.  
  3. 请推断并填写出小明的出生年份。
  4.  
  5. 这是一个4位整数,请通过浏览器提交答案,不要填写任何多余的内容(比如,他表弟的出生年份,或是他们的年龄等等)
  6.  
  7. 1988
  1. public class Main {
  2.  
  3. public static void main(String[] args) {
  4. for(int i = 1900;i <= 2014;i++) {
  5. int a = i / 1000 + i / 100 % 10 + i / 10 % 10 + i % 10;
  6. if(a == 2014 - i)
  7. System.out.println("i = "+i);
  8. }
  9.  
  10. }
  11. }

2 出栈次序

  1. X星球特别讲究秩序,所有道路都是单行线。一个甲壳虫车队,共16辆车,按照编号先后发车,夹在其它车流中,缓缓前行。
  2.  
  3. 路边有个死胡同,只能容一辆车通过,是临时的检查站,如图【p1.png】所示。
  4.  
  5. X星球太死板,要求每辆路过的车必须进入检查站,也可能不检查就放行,也可能仔细检查。
  6.  
  7. 如果车辆进入检查站和离开的次序可以任意交错。那么,该车队再次上路后,可能的次序有多少种?
  8.  
  9. 为了方便起见,假设检查站可容纳任意数量的汽车。
  10.  
  11. 显然,如果车队只有1辆车,可能次序1种;2辆车可能次序2种;3辆车可能次序5种。
  12.  
  13. 现在足足有16辆车啊,亲!需要你计算出可能次序的数目。
  14.  
  15. 这是一个整数,请通过浏览器提交答案,不要填写任何多余的内容(比如说明性文字)。
  16.  
  17. 35357670

  1. public class Main {
  2. public static int count = 1;
  3.  
  4. public void dfs(int step, int num, int car) {
  5. if(step == num) //当所有排队的汽车均已进栈后
  6. return;
  7. dfs(step + 1, num, car + 1);
  8. if(car > 0) { //当栈不为空时,可以选择出栈
  9. count++;
  10. dfs(step, num, car - 1);
  11. }
  12. }
  13.  
  14. public static void main(String[] args) {
  15. Main test = new Main();
  16. test.dfs(0, 16, 0);
  17. System.out.println("DFS: "+count);
  18. int r = 1;
  19. for(int i = 2;i <= 16;i++) {
  20. r = r * (4 * i - 2) / (i + 1); //借鉴网上网友思想:利用卡特兰数
  21. }
  22. System.out.println(r);
  23. }
  24. }

3 信号匹配

  1. X星球接收了一个数字信号序列。
  2.  
  3. 现有一个已知的样板序列。需要在信号序列中查找它首次出现的位置。这类似于串的匹配操作。
  4.  
  5. 如果信号序列较长,样板序列中重复数字较多,就应当注意比较的策略了。可以仿照串的KMP算法,进行无回溯的匹配。这种匹配方法的关键是构造next数组。
  6.  
  7. next[i] 表示第i项比较失配时,样板序列向右滑动,需要重新比较的项的序号。如果为-1,表示母序列可以进入失配位置的下一个位置进行新的比较。
  8.  
  9. 下面的代码实现了这个功能,请仔细阅读源码,推断划线位置缺失的代码。
  10.  
  11. // 生成next数组
  12. int* make_next(int pa[], int pn)
  13. {
  14. int* next = (int*)malloc(sizeof(int)*pn);
  15. next[0] = -1;
  16. int j = 0;
  17. int k = -1;
  18. while(j < pn-1){
  19. if(k==-1 || pa[j]==pa[k]){
  20. j++;
  21. k++;
  22. next[j] = k;
  23. }
  24. else
  25. k = next[k];
  26. }
  27.  
  28. return next;
  29. }
  30.  
  31. // da中搜索pa, da的长度为an, pa的长度为pn
  32. int find(int da[], int an, int pa[], int pn)
  33. {
  34. int rst = -1;
  35. int* next = make_next(pa, pn);
  36. int i=0; // da中的指针
  37. int j=0; // pa中的指针
  38. int n = 0;
  39. while(i<an){
  40. n++;
  41. if(da[i]==pa[j] || j==-1){
  42. i++;
  43. j++;
  44. }
  45. else
  46. __________________________; //填空位置
  47.  
  48. if(j==pn) {
  49. rst = i-pn;
  50. break;
  51. }
  52. }
  53.  
  54. free(next);
  55.  
  56. return rst;
  57. }
  58.  
  59. int main()
  60. {
  61. int da[] = {1,2,1,2,1,1,2,1,2,1,1,2,1,1,2,1,1,2,1,2,1,1,2,1,1,2,1,1,1,2,1,2,3};
  62. int pa[] = {1,2,1,1,2,1,1,1,2};
  63.  
  64. int n = find(da, sizeof(da)/sizeof(int), pa, sizeof(pa)/sizeof(int));
  65. printf("%d\n", n);
  66.  
  67. return 0;
  68. }
  69.  
  70. 注意:通过浏览器提交答案。只填写缺少的内容,不要填写任何多余的内容(例如:说明性文字或已有符号)
  71.  
  72. j = next[j]

4 生物芯片

  1. X博士正在研究一种生物芯片,其逻辑密集度、容量都远远高于普通的半导体芯片。
  2.  
  3. 博士在芯片中设计了 n 个微型光源,每个光源操作一次就会改变其状态,即:点亮转为关闭,或关闭转为点亮。
  4.  
  5. 这些光源的编号从 1 n,开始的时候所有光源都是关闭的。
  6.  
  7. 博士计划在芯片上执行如下动作:
  8.  
  9. 所有编号为2的倍数的光源操作一次,也就是把 2 4 6 8 ... 等序号光源打开
  10.  
  11. 所有编号为3的倍数的光源操作一次, 也就是对 3 6 9 ... 等序号光源操作,注意此时6号光源又关闭了。
  12.  
  13. 所有编号为4的倍数的光源操作一次。
  14.  
  15. .....
  16.  
  17. 直到编号为 n 的倍数的光源操作一次。
  18.  
  19. X博士想知道:经过这些操作后,某个区间中的哪些光源是点亮的。
  20.  
  21. 【输入格式】
  22. 3个用空格分开的整数:N L R (L<R<N<10^15) N表示光源数,L表示区间的左边界,R表示区间的右边界。
  23.  
  24. 【输出格式】
  25. 输出1个整数,表示经过所有操作后,[L,R] 区间中有多少个光源是点亮的。
  26.  
  27. 例如:
  28. 输入:
  29. 5 2 3
  30. 程序应该输出:
  31. 2
  32.  
  33. 再例如:
  34. 输入:
  35. 10 3 6
  36. 程序应该输出:
  37. 3
  38.  
  39. 资源约定:
  40. 峰值内存消耗 < 256M
  41. CPU消耗 < 1000ms
  42.  
  43. 请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
  44.  
  45. 所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
  46.  
  47. 注意: main函数需要返回0
  48. 注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。
  49. 注意: 所有依赖的函数必须明确地在源文件中 #include <xxx> 不能通过工程设置而省略常用头文件。
  50.  
  51. 提交时,注意选择所期望的编译器类型。
  1. import java.util.Scanner;
  2.  
  3. public class Main {
  4.  
  5. public long getP(long X) {
  6. long count = 1;
  7. for(long i = 2;i <= X / 2;i++) {
  8. if(X % i == 0)
  9. count++;
  10. }
  11. return count;
  12. }
  13.  
  14. public void getResult(long N, long L, long R) {
  15. long result = 0;
  16. for(long i = L;i <= R;i++) {
  17. long count = getP(i);
  18. if((count&1) == 1)
  19. result++;
  20. }
  21. System.out.println(result);
  22. }
  23.  
  24. //完全平方数的因子数为奇数个,其中因子包含1
  25. public void getResult1(long N, long L, long R) {
  26. long result = R - L + 1;
  27. long start = (long) Math.sqrt(L);
  28. if(start * start < L)
  29. start = start + 1;
  30. for(;start * start <= R;start++) {
  31. if(start * start >= L && start * start <= R)
  32. result--;
  33. }
  34. System.out.println("借鉴网友解法:"+result);
  35. }
  36.  
  37. public static void main(String[] args) {
  38. Main test = new Main();
  39. Scanner in = new Scanner(System.in);
  40. long N = in.nextLong();
  41. long L = in.nextLong();
  42. long R = in.nextLong();
  43. test.getResult(N, L, R);
  44. test.getResult1(N, L, R);
  45. }
  46.  
  47. }

5 Log大侠

  1. atm参加了速算训练班,经过刻苦修炼,对以2为底的对数算得飞快,人称Log大侠。
  2.  
  3. 一天,Log大侠的好友 drd 有一些整数序列需要变换,Log大侠正好施展法力...
  4.  
  5. 变换的规则是: 对其某个子序列的每个整数变为: [log_2 (x) + 1] 其中 [] 表示向下取整,就是对每个数字求以2为底的对数,然后取下整。
  6. 例如对序列 3 4 2 操作一次后,这个序列会变成 2 3 2
  7.  
  8. drd需要知道,每次这样操作后,序列的和是多少。
  9.  
  10. 【输入格式】
  11. 第一行两个正整数 n m
  12. 第二行 n 个数,表示整数序列,都是正数。
  13. 接下来 m 行,每行两个数 L R 表示 atm 这次操作的是区间 [L, R],数列序号从1开始。
  14.  
  15. 【输出格式】
  16. 输出 m 行,依次表示 atm 每做完一个操作后,整个序列的和。
  17.  
  18. 例如,输入:
  19. 3 3
  20. 5 6 4
  21. 1 2
  22. 2 3
  23. 1 3
  24.  
  25. 程序应该输出:
  26. 10
  27. 8
  28. 6
  29.  
  30. 【数据范围】
  31. 对于 30% 的数据, n, m <= 10^3
  32. 对于 100% 的数据, n, m <= 10^5
  33.  
  34. 资源约定:
  35. 峰值内存消耗 < 256M
  36. CPU消耗 < 1000ms
  37.  
  38. 请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
  39.  
  40. 所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
  41.  
  42. 注意: main函数需要返回0
  43. 注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。
  44. 注意: 所有依赖的函数必须明确地在源文件中 #include <xxx> 不能通过工程设置而省略常用头文件。
  45.  
  46. 提交时,注意选择所期望的编译器类型。
  1. import java.util.Scanner;
  2.  
  3. public class Main {
  4. public static long sum = 0L;
  5. public static int[] number;
  6. public static long[] result;
  7.  
  8. public int getLog2(int X) {
  9. int count = 0;
  10. while(X >= 2) {
  11. X = X / 2;
  12. count++;
  13. }
  14. return count;
  15. }
  16.  
  17. public void getResult(int L, int R) {
  18. for(int i = L;i <= R;i++) {
  19. sum = sum - number[i];
  20. number[i] = getLog2(number[i]) + 1;
  21. sum = sum + number[i];
  22. }
  23. }
  24.  
  25. public static void main(String[] args) {
  26. Main test = new Main();
  27. Scanner in = new Scanner(System.in);
  28. int n = in.nextInt();
  29. int m = in.nextInt();
  30. number = new int[n + 1];
  31. for(int i = 1;i <= n;i++) {
  32. number[i] = in.nextInt();
  33. sum = sum + number[i];
  34. }
  35. result = new long[m];
  36. for(int i = 0;i < m;i++) {
  37. int L = in.nextInt();
  38. int R = in.nextInt();
  39. test.getResult(L, R);
  40. result[i] = sum;
  41. }
  42. for(int i = 0;i < m;i++)
  43. System.out.println(result[i]);
  44. }
  45. }

6 殖民地

  1. 带着殖民扩张的野心,Pear和他的星际舰队登上X星球的某平原。为了评估这块土地的潜在价值,Pear把它划分成了M*N格,每个格子上用一个整数(可正可负)表示它的价值。
  2.  
  3. Pear要做的事很简单——选择一些格子,占领这些土地,通过建立围栏把它们和其它土地隔开。对于M*N的格子,一共有(M+1)*N+M*(N+1)条围栏,即每个格子都有上下左右四个围栏;不在边界上的围栏被相邻的两个格子公用。大概如下图【p1.png】所示。
  4.  
  5. 图中,蓝色的一段是围栏,属于格子12;红色的一段是围栏,属于格子34
  6.  
  7. 每个格子有一个可正可负的收益,而建围栏的代价则一定是正的。
  8.  
  9. 你需要选择一些格子,然后选择一些围栏把它们围起来,使得所有选择的格子和所有没被选的格子严格的被隔开。选择的格子可以不连通,也可以有“洞”,即一个连通块中间有一些格子没选。注意,若中间有“洞”,那么根据定义,“洞”和连通块也必须被隔开。
  10.  
  11. Pear的目标很明确,花最小的代价,获得最大的收益。
  12.  
  13. 【输入数据】
  14. 输入第一行两个正整数M N,表示行数和列数。
  15. 接下来M行,每行N个整数,构成矩阵AA[i,j]表示第i行第j列格子的价值。
  16. 接下来M+1行,每行N个整数,构成矩阵BB[i,j]表示第i行第j列上方的围栏建立代价。
  17. 特别的,B[M+1,j]表示第M行第j列下方的围栏建立代价。
  18. 接下来M行,每行N+1个整数,构成矩阵CC[i,j]表示第i行第j列左方的围栏建立代价。
  19. 特别的,C[i,N+1]表示第i行第N列右方的围栏建立代价。
  20.  
  21. 【输出数据】
  22. 一行。只有一个正整数,表示最大收益。
  23.  
  24. 【输入样例1
  25. 3 3
  26. 65 -6 -11
  27. 15 65 32
  28. -8 5 66
  29. 4 1 6
  30. 7 3 11
  31. 23 21 22
  32. 5 25 22
  33. 26 1 1 13
  34. 16 3 3 4
  35. 6 3 1 2
  36.  
  37. 程序应当输出:
  38. 123
  39.  
  40. 【输入样例2
  41. 6 6
  42. 72 2 -7 1 43 -12
  43. 74 74 -14 35 5 3
  44. 31 71 -12 70 38 66
  45. 40 -6 8 52 3 78
  46. 50 11 62 20 -6 61
  47. 76 55 67 28 -19 68
  48. 25 4 5 8 30 5
  49. 9 20 29 20 6 18
  50. 3 19 20 11 5 15
  51. 10 3 19 23 6 24
  52. 27 8 16 10 5 22
  53. 28 14 1 5 1 24
  54. 2 13 15 17 23 28
  55. 24 11 27 16 12 13 27
  56. 19 15 21 6 21 11 5
  57. 2 3 1 11 10 20 9
  58. 8 28 1 21 9 5 7
  59. 16 20 26 2 22 5 12
  60. 30 27 16 26 9 6 23
  61.  
  62. 程序应当输出
  63. 870
  64.  
  65. 【数据范围】
  66. 对于20%的数据,M,N<=4
  67. 对于50%的数据,M,N<=15
  68. 对于100%的数据,M,N<=200
  69. ABC数组(所有的涉及到的格子、围栏输入数据)绝对值均不超过1000。根据题意,A数组可正可负,BC数组均为正整数。
  70.  
  71. 资源约定:
  72. 峰值内存消耗 < 256M
  73. CPU消耗 < 3000ms
  74.  
  75. 请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
  76.  
  77. 所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
  78.  
  79. 注意: main函数需要返回0
  80. 注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。
  81. 注意: 所有依赖的函数必须明确地在源文件中 #include <xxx> 不能通过工程设置而省略常用头文件。
  82.  
  83. 提交时,注意选择所期望的编译器类型。

PS:此题未写出正确解答,初步一看,使用贪心法求解,但是调试了好久,只能通过题目给定的第一组数据,下面的代码只能通过题目所给的第一组数据,代表楼主自己当时解题的想法,仅仅是记录一下自己的思考的过程,希望能够给其他同学带来启发。

  1. import java.util.Scanner;
  2.  
  3. public class Main {
  4. public static int m, n;
  5. public static int[][] A;
  6. public static int[][] B;
  7. public static int[][] C;
  8. public int[][] step = {{0,1},{1,0}}; //分表表示在M*N单元格中向右、向下行走一步
  9. public int[][] step1 = {{-1,0},{1,0},{0,-1},{0,1}};//分别表示向上、下、左、右行走一步
  10.  
  11. public void init() {
  12. A = new int[m][n];
  13. B = new int[m + 1][n];
  14. C = new int[m][n + 1];
  15. }
  16.  
  17. public void getResult() {
  18. int[][] judge = new int[n][m];
  19. for(int i = 0;i < n;i++)
  20. for(int j = 0;j < m;j++)
  21. if(A[i][j] < 0) //收益为负数,直接舍弃
  22. judge[i][j] = -1;
  23. for(int i = 0;i < m;i++)
  24. for(int j = 0;j < n;j++) {
  25. int v = B[i][j] + B[i + 1][j] + C[i][j] + C[i][j + 1];
  26. A[i][j] = A[i][j] - v;
  27. if(A[i][j] >= 0) //减去围栏造价,收益不为负,一定收录
  28. judge[i][j] = 1;
  29. }
  30. for(int i = 0;i < m;i++) //处理相邻围栏重复问题
  31. for(int j = 0;j < n;j++) {
  32. if(judge[i][j] == -1 || judge[i][j] == 0)
  33. continue;
  34. for(int k = 0;k < 2;k++) {
  35. int x = i + step[k][0];
  36. int y = j + step[k][1];
  37. if(x < m && y < n) {
  38. if(judge[x][y] == 1) {
  39. if(k == 0) {
  40. A[i][j] = A[i][j] + C[x][y];
  41. A[x][y] = A[x][y] + C[x][y];
  42. }
  43. else {
  44. A[i][j] = A[i][j] + B[x][y];
  45. A[x][y] = A[x][y] + B[x][y];
  46. }
  47. }
  48. }
  49. }
  50. }
  51. //重新扫描,选取可能符合要求的单元格
  52. for(int i = 0;i < m;i++)
  53. for(int j = 0;j < n;j++) {
  54. if(judge[i][j] != 1) {
  55. for(int k = 0;k < 4;k++) {
  56. int x = i + step1[k][0];
  57. int y = j + step1[k][1];
  58. if(x < m && y < n && x >= 0 && y >= 0 && judge[x][y] == 1) {
  59. if(k == 0) {
  60. A[i][j] = A[i][j] + 2 * B[x + 1][y];
  61. }
  62. else if(k == 1){
  63. A[i][j] = A[i][j] + 2 * B[x][y];
  64. } else if(k == 2) {
  65. A[i][j] = A[i][j] + 2 * C[x][y + 1];
  66. } else {
  67. A[i][j] = A[i][j] + 2 * C[x][y];
  68. }
  69. }
  70. }
  71. if(A[i][j] >= 0)
  72. judge[i][j] = 1;
  73. else {
  74. for(int k = 0;k < 4;k++) {
  75. int x = i + step1[k][0];
  76. int y = j + step1[k][1];
  77. if(x < m && y < n && x >= 0 && y >= 0 && judge[x][y] == 1) {
  78. if(k == 0) {
  79. A[i][j] = A[i][j] - 2 * B[x + 1][y];
  80. }
  81. else if(k == 1){
  82. A[i][j] = A[i][j] - 2 * B[x][y];
  83. } else if(k == 2) {
  84. A[i][j] = A[i][j] - 2 * C[x][y + 1];
  85. } else {
  86. A[i][j] = A[i][j] - 2 * C[x][y];
  87. }
  88. }
  89. }
  90. }
  91. }
  92. }
  93. int sum = 0;
  94. for(int i = 0;i < m;i++)
  95. for(int j = 0;j < n;j++)
  96. if(A[i][j] >= 0)
  97. sum = sum + A[i][j];
  98. System.out.println(sum);
  99. }
  100.  
  101. public static void main(String[] args) {
  102. Main test = new Main();
  103. Scanner in = new Scanner(System.in);
  104. m = in.nextInt();
  105. n = in.nextInt();
  106. test.init();
  107. for(int i = 0;i < m;i++)
  108. for(int j = 0;j < n;j++)
  109. A[i][j] = in.nextInt();
  110. for(int i = 0;i < m + 1;i++)
  111. for(int j = 0;j < n;j++)
  112. B[i][j] = in.nextInt();
  113. for(int i = 0;i < m;i++)
  114. for(int j = 0;j < n + 1;j++)
  115. C[i][j] = in.nextInt();
  116. test.getResult();
  117. }
  118. }

算法笔记_205:第五届蓝桥杯软件类决赛真题(C语言B组)的更多相关文章

  1. 算法笔记_206:第五届蓝桥杯软件类决赛真题(Java语言A组)

    目录 1 海盗分金币 2 六角幻方 3 格子放鸡蛋 4 排列序数 5 幂一矩阵 6 供水设施    前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 海盗分金币 有5个海盗,相约进行一次帆船比赛. 比 ...

  2. 算法笔记_204:第四届蓝桥杯软件类决赛真题(Java语言C组)

    目录 1 好好学习 2 埃及分数 3 金蝉素数 4 横向打印二叉树 5 危险系数 6 公式求值   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 好好学习 汤姆跟爷爷来中国旅游.一天,他帮助中国的 ...

  3. 算法笔记_203:第四届蓝桥杯软件类决赛真题(C语言B组)

    目录 1 猜灯谜 2 连续奇数和 3 空白格式化 4 高僧斗法 5 格子刷油漆 6 农场阳光   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 猜灯谜 标题:猜灯谜 A 村的元宵节灯会上有一迷题: ...

  4. 算法笔记_200:第三届蓝桥杯软件类决赛真题(C语言本科)

    目录 1 星期几 2 数据压缩 3 拼音字母 4 DNA比对 5 方块填数   前言:以下代码部分仅供参考,若有不当之处,还望路过同学指出哦~ 1 星期几 1949年的国庆节(10月1日)是星期六. ...

  5. 算法笔记_208:第六届蓝桥杯软件类决赛真题(Java语言A组)

    目录 1 胡同门牌号 2 四阶幻方 3 显示二叉树 4 穿越雷区 5 切开字符串 6 铺瓷砖   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 胡同门牌号 标题:胡同门牌号 小明家住在一条胡同里. ...

  6. 算法笔记_202:第三届蓝桥杯软件类决赛真题(Java高职)

    目录 1 填算式 2 提取子串 3 机器人行走 4 地址格式转换 5 排日程   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 填算式 [结果填空] (满分11分) 看这个算式: ☆☆☆ + ☆☆ ...

  7. 算法笔记_210:第六届蓝桥杯软件类决赛真题(Java语言C组)

    目录 1 机器人数目 2 生成回文数 3 空心菱形 4 奇怪的数列 5 密文搜索 6 居民集会 前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 机器人数目 标题:机器人数目 少年宫新近邮购了小机器人 ...

  8. 算法笔记_201:第三届蓝桥杯软件类决赛真题(Java本科)

    目录 1 数量周期 2 提取子串 3 源码变换 4 古代赌局 5 火柴游戏   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 数量周期 [结果填空](满分9分) 复杂现象背后的推动力,可能是极其简 ...

  9. 算法笔记_199:第二届蓝桥杯软件类决赛真题(C语言本科)

    前言:以下代码部分仅供参考,C语言解答部分全部来自网友,Java语言部分部分参考自网友,对于答案的正确性不能完全保证. 试题1 数论中有著名的四方定理:所有自然数至多只要用四个数的平方和就可以表示. ...

随机推荐

  1. 明日传奇第三季/全集Legends of Tomorrow迅雷下载

    <明日传奇>第三季将加入一名新的女性角色.据Variety得到的消息称,塔拉·阿什(Tala Ashe)将作为<明日传奇>第三季的常规演员加入该剧.在第三季中,塔拉·阿什饰演的 ...

  2. Android之greenDao,一个orm的使用

    转自:http://blog.csdn.net/krislight/article/details/9391455 greenDaoMaster的学习研究 分类: 心得笔记 2013-07-20 16 ...

  3. 简析Window、Activity、DecorView以及ViewRoot之间的错综关系

    一.职能简介 Activity Activity并不负责视图控制,它只是控制生命周期和处理事件.真正控制视图的是Window.一个Activity包含了一个Window,Window才是真正代表一个窗 ...

  4. golang常用模块介绍

    golang模块 一.命令行库Cobra Cobra提供简单的接口来创建强大的现代化CLI接口,比如git与go工具.Cobra同时也是一个程序, 用于创建CLI程序 https://www.jian ...

  5. Java调用DLL有多种方式,常用的方式有JNative、JNA、JNI等。

    JNative方式调用dll JNative是一种能够使Java语言使调用DLL的一种技术,对JNI进行了封装,可能有些读者会有这样一个问题,JNative对JNI进行了封装,并且是一种跨语言的使用D ...

  6. Leap Motion 上手体验

    很早之前就关注了Leap Motion这个颠覆性的体感操作设备,如今7月22日上市至今已经一个月左右,淘宝的价格也已经降到650元,虽说相对国外还是偏贵,但是已经忍不住尝尝鲜了. Leap Motio ...

  7. Oracle选择性系统授权

    Selective System Grants 问题: 我只想授予XX用户alter system set user_dump_dest 权限! I want to give users the ab ...

  8. 样条之贝塞尔(Bezier)

    我曾经发过两篇关于贝塞尔的文章:数学图形(1.47)贝塞尔(Bézier)曲线,数学图形之贝塞尔(Bézier)曲面.那是使用我自己定义的脚本语言生成贝塞尔图形.由于我自己定义的脚本语法功能有限,所以 ...

  9. 里诺全系列注册机+暗桩patch

    一直有坛友私信更新里诺,今天花了一天时间,将里诺全系列更新完毕,权当送给坛友们的新年礼物吧! 全系列开放至元旦假期结束,后面就随机开放了. <ignore_js_op> 使用说明: 1.选 ...

  10. scrapy框架系列 (5) Spider类

    Spider Spider类定义了如何爬取某个(或某些)网站.包括了爬取的动作(例如:是否跟进链接)以及如何从网页的内容中提取结构化数据(爬取item). 换句话说,Spider就是您定义爬取的动作及 ...