这个作业属于那个课程 C语言程序设计II
这个作业要求在哪里 这里
我在这个课程的目标是 能按自己的想法解出题目
这个作业在那个具体方面帮助我实现目标 能朝着软件工程师方向发展
参考文献与网址 C语言程序设计II(第三版) C语言的教学

题目:汉诺塔问题

汉诺塔是一个源于印度古老传说的益智玩具。据说大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘,大梵天命令僧侣把圆盘移到另一根柱子上,并且规定:在小圆盘上不能放大圆盘,每次只能移动一个圆盘。当所有圆盘都移到另一根柱子上时,世界就会毁灭。

请编写程序,输入汉诺塔圆片的数量,输出移动汉诺塔的步骤。

输入格式

  1. 圆盘数 起始柱 目的柱 过度柱

输出格式

  1. 移动汉诺塔的步骤
  2. 每行显示一步操作,具体格式为:
  3. 盘片号: 起始柱 -> 目的柱
  4. 其中盘片号从 1 开始由小到大顺序编号。

输入样例

  1. 3
  2. a c b

输出样例

  1. 1: a -> c
  2. 2: a -> b
  3. 1: c -> b
  4. 3: a -> c
  5. 1: b -> a
  6. 2: b -> c
  7. 1: a -> c

我的代码

  1. #include<stdio.h>
  2. void move(int n,char a,char b,char c)
  3. {
  4. if(n==1)
  5. printf("\t%c->%c\n",a,c);
  6. else
  7. {
  8. move(n-1,a,c,b);
  9. printf("\t%c->%c\n",a,c);
  10. move(n-1,b,a,c);
  11. }
  12. }
  13. main()
  14. {
  15. int n;
  16. printf("请输入数字n(要移动的块数)以解决n阶汉诺塔问题:");
  17. scanf("%d",&n);
  18.   move(n,'a','b','c');
  19. while(1);
  20. }

解题流程图

本题遇见的问题与解决办法

到处都是问题,达到了无法用言语表达的地步

运行结果截图

题目:估值一亿的AI核心代码

上图来自网络

本题要求你实现一个稍微更值钱一点的 AI 英文问答程序,规则是:

无论用户说什么,首先把对方说的话在一行中原样打印出来;

消除原文中多余空格:把相邻单词间的多个空格换成 1 个空格,把行首尾的空格全部删掉,把标点符号前面的空格删掉;

把原文中所有大写英文字母变成小写,除了 I;

把原文中所有独立的 can you、could you 对应地换成 I can、I could—— 这里“独立”是指被空格或标点符号分隔开的单词;

把原文中所有独立的 I 和 me 换成 you;

把原文中所有的问号 ? 换成惊叹号 !;

在一行中输出替换后的句子作为 AI 的回答。

输入格式:

输入首先在第一行给出不超过 10 的正整数 N,随后 N 行,每行给出一句不超过 1000 个字符的、以回车结尾的用户的对话,对话为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。

输出格式:

按题面要求输出,每个 AI 的回答前要加上 AI: 和一个空格。

输入样例:

  1. 6
  2. Hello ?
  3. Good to chat with you
  4. can you speak Chinese?
  5. Really?
  6. Could you show me 5
  7. What Is this prime? I,don 't know

输出样例:

  1. Hello ?
  2. AI: hello!
  3. Good to chat with you
  4. AI: good to chat with you
  5. can you speak Chinese?
  6. AI: I can speak chinese!
  7. Really?
  8. AI: really!
  9. Could you show me 5
  10. AI: I could show you 5
  11. What Is this prime? I,don 't know
  12. AI: what Is this prime! you,don't know

我的代码

  1. #include<iostream>
  2. #include<ctype.h>
  3. #include<vector>
  4. #include<string>
  5. using namespace std;
  6. vector<string>v;
  7. int main()
  8. {
  9. int n;
  10. string s;
  11. cin>>n;
  12. getchar();
  13. while(n--)
  14. {
  15. getline(cin,s);
  16. cout<<s<<endl<<"AI: ";
  17. int len=s.length();
  18. for(int i=0;i<len;i++)
  19. {
  20. if(s[i]=='?')
  21. s[i]='!';
  22. else if(isupper(s[i])&&s[i]!='I')
  23. s[i]=tolower(s[i]);
  24. }
  25. v.clear();
  26. for(int i=0;i<len;)
  27. {
  28. string tmp="";
  29. if(isalpha(s[i]))
  30. {
  31. while(i<len&&isalpha(s[i])) tmp+=s[i++];
  32. }
  33. else if(isdigit(s[i]))
  34. {
  35. while(i<len&&isdigit(s[i])) tmp+=s[i++];
  36. }
  37. else if(s[i]==' ')
  38. {
  39. tmp=" ";
  40. while(i<len&&s[i]==' ') i++;
  41. }
  42. else
  43. {
  44. tmp+=s[i];
  45. i++;
  46. if(v.size()>0&&v.back()==" ") v.pop_back();
  47. }
  48. if(tmp==" "&&(v.empty()||i==len)) continue;
  49. v.push_back(tmp);
  50. }
  51. for(int i=0;i<v.size();i++)
  52. if(v[i]=="I"||v[i]=="me")
  53. v[i]="you";
  54. else if(v[i]=="you")
  55. {
  56. if(i<2||!(v[i-1].length()==1&&(!isalnum(v[i-1][0])))) continue;
  57. if(v[i-2]=="can")
  58. v[i-2]="I",v[i]="can";
  59. else if(v[i-2]=="could")
  60. v[i-2]="I",v[i]="could";
  61. }
  62. for(int i=0;i<v.size();i++)
  63. cout<<v[i];
  64. cout<<endl;
  65. }
  66. return 0;
  67. }

解题流程图

本题遇见的问题与解决办法

到处都是问题,达到了无法用言语表达的地步

运行结果截图

题目:***八皇后问题

在国际象棋中,皇后是最厉害的棋子,可以横走、直走,还可以斜走。棋手马克斯·贝瑟尔 1848 年提出著名的八皇后问题:即在 8 × 8 的棋盘上摆放八个皇后,使其不能互相攻击 —— 即任意两个皇后都不能处于同一行、同一列或同一条斜线上。

现在我们把棋盘扩展到 n × n 的棋盘上摆放 n 个皇后,请问该怎么摆?请编写程序,输入正整数 n,输出全部摆法(棋盘格子空白处显示句点“.”,皇后处显示字母“Q”,每两格之间空一格)。

输入格式

  1. 正整数 n (0 n 12)

输出格式

  1. 若问题有解,则输出全部摆法(两种摆法之间空一行),否则输出 None

要求:试探的顺序逐行从左往右的顺序进行,请参看输出样例2。

输入样例1

  1. 3

输出样例1

  1. None

输入样例2

  1. 6

输出样例2

  1. . Q . . . .
  2. . . . Q . .
  3. . . . . . Q
  4. Q . . . . .
  5. . . Q . . .
  6. . . . . Q .
  7. . . Q . . .
  8. . . . . . Q
  9. . Q . . . .
  10. . . . . Q .
  11. Q . . . . .
  12. . . . Q . .
  13. . . . Q . .
  14. Q . . . . .
  15. . . . . Q .
  16. . Q . . . .
  17. . . . . . Q
  18. . . Q . . .
  19. . . . . Q .
  20. . . Q . . .
  21. Q . . . . .
  22. . . . . . Q
  23. . . . Q . .
  24. . Q . . . .

我的代码

  1. #include <stdio.h>
  2. int Queenes[8]={0},Counts=0;
  3. int Check(int line,int list){
  4. for (int index=0; index<line; index++) {
  5. int data=Queenes[index];
  6. if (list==data) {
  7. return 0;
  8. }
  9. if ((index+data)==(line+list)) {
  10. return 0;
  11. }
  12. return 0;
  13. }
  14. }
  15. return 1;
  16. }
  17. void print()
  18. {
  19. for (int line = 0; line < 8; line++)
  20. {
  21. int list;
  22. for (list = 0; list < Queenes[line]; list++)
  23. printf("0");
  24. printf("#");
  25. for (list = Queenes[line] + 1; list < 8; list++){
  26. printf("0");
  27. }
  28. printf("\n");
  29. }
  30. printf("================\n");
  31. }
  32. void eight_queen(int line){
  33. for (int list=0; list<8; list++) {
  34. if (Check(line, list)) {
  35. Queenes[line]=list;
  36. if (line==7) {
  37. Counts++;
  38. print();
  39. Queenes[line]=0;
  40. return;
  41. }
  42. eight_queen(line+1);
  43. Queenes[line]=0;
  44. }
  45. }
  46. }
  47. int main() {
  48. eight_queen(0);
  49. printf("摆放的方式有%d种",Counts);
  50. return 0;
  51. }

解题流程图

本题遇见的问题与解决办法

到处都是问题,达到了无法用言语表达的地步

运行结果截图

何为数组指针?

数组指针,指的是数组名的指针,即数组首元素地址的指针。即是指向数组的指针。例:int (*p)[10]; p即为指向数组的指针,又称数组指针。

解释来源于百度百科

比如。。。

  1. #include "stdafx.h"
  2. int main()
  3. {
  4. //一维数组
  5. int a[5] = { 1, 2, 3, 4, 5 };
  6. //步长为5的数组指针,即数组里有5个元素
  7. int (*p)[5];
  8. //把数组a的地址赋给p,则p为数组a的地址,则*p表示数组a本身
  9. p = &a;
  10. //%p输出地址, %d输出十进制
  11. //\n回车
  12. //在C中,在几乎所有使用数组的表达式中,数组名的值是个指针常量,也就是数组第一个元素的地址,它的类型取决于数组元素的类型。
  13. printf("%p\n", a); //输出数组名,一般用数组的首元素地址来标识一个数组,则输出数组首元素地址
  14. printf("%p\n", p); //根据上面,p为数组a的地址,输出数组a的地址
  15. printf("%p\n", *p); //*p表示数组a本身,一般用数组的首元素地址来标识一个数组
  16. printf("%p\n", &a[0]); //a[0]的地址
  17. printf("%p\n", &a[1]); //a[1]的地址
  18. printf("%p\n", p[0]); //数组首元素的地址
  19. printf("%d\n", **p); //*p为数组a本身,即为数组a首元素地址,则*(*p)为值,当*p为数组首元素地址时,**p表示首元素的值1
  20. printf("%d\n", *p[0]); //根据优先级,p[0] 表示首元素地址,则*p[0]表示首元素本身,即首元素的值1
  21. printf("%d\n", *p[1]); //为一个绝对值很大的负数,不表示a[1]...表示什么我还不知道
  22. //将二维数组赋给指针
  23. int b[3][4];
  24. int(*pp)[4]; //定义一个数组指针,指向含4个元素的一维数组
  25. pp = b; //将该二维数组的首地址赋给pp,也就是b[0]或&b[0],二维数组中pp=b和pp=&b[0]是等价的
  26. pp++; //pp=pp+1,该语句执行过后pp的指向从行b[0][]变为了行b[1][],pp=&b[1]
  27. int k;
  28. scanf_s("%d", &k);
  29. return 0;
  30. }

何为指针数组?

在C语言和C++语言中,数组元素全为指针的数组称为指针数组。

一维指针数组的定义形式为:“类型名 *数组标识符[数组长度]”。

例如,一个一维指针数组的定义:int *ptr_array[10]。

解释来源于百度百科

例如。。。

  1. #include "stdafx.h"
  2. int main()
  3. {
  4. int a = 1;
  5. int b = 2;
  6. int *p[2];
  7. p[0] = &a;
  8. p[1] = &b;
  9. printf("%p\n", p[0]); //a的地址
  10. printf("%p\n", &a); //a的地址
  11. printf("%p\n", p[1]); //b的地址
  12. printf("%p\n", &b); //b的地址
  13. printf("%d\n", *p[0]); //p[0]表示a的地址,则*p[0]表示a的值
  14. printf("%d\n", *p[1]); //p[1]表示b的地址,则*p[1]表示b的值
  15. //将二维数组赋给指针数组
  16. int *pp[3]; //一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2],所以要分别赋值
  17. int c[3][4];
  18. for (int i = 0; i<3; i++)
  19. pp[i] = c[i];
  20. int k;
  21. scanf_s("%d", &k);
  22. return 0;
  23. }

何为指针函数?

指针函数是一个函数。函数都有返回类型(如果不返回值,则为无值型),只不过指针函数返回类型是某一类型的指针。

解释来源于百度百科

像。。。

  1. typedef struct _Data{
  2. int a;
  3. int b;
  4. }Data;
  5. //指针函数
  6. Data* f(int a,int b){
  7. Data * data = new Data;
  8. data->a = a;
  9. data->b = b;
  10. return data;
  11. }
  12. int main(int argc, char *argv[])
  13. {
  14. QApplication a(argc, argv);
  15. //调用指针函数
  16. Data * myData = f(4,5);
  17. qDebug() << "f(4,5) = " << myData->a << myData->b;
  18. return a.exec();
  19. }

何为函数指针?

函数指针是指向函数的指针变量。 因此“函数指针”本身首先应是指针变量,只不过该指针变量指向函数。这正如用指针变量可指向整型变量、字符型、数组一样,这里是指向函数。如前所述,C在编译时,每一个函数都有一个入口地址,该入口地址就是函数指针所指向的地址。有了指向函数的指针变量后,可用该指针变量调用函数,就如同用指针变量可引用其他类型变量一样,在这些概念上是大体一致的。函数指针有两个用途:调用函数和做函数的参数。

解释来源于百度百科

那么。。。

  1. int add(int x,int y){
  2. return x+y;
  3. }
  4. int sub(int x,int y){
  5. return x-y;
  6. }
  7. //函数指针
  8. int (*fun)(int x,int y);
  9. int main(int argc, char *argv[])
  10. {
  11. QApplication a(argc, argv);
  12. //第一种写法
  13. fun = add;
  14. qDebug() << "(*fun)(1,2) = " << (*fun)(1,2) ;
  15. //第二种写法
  16. fun = &sub;
  17. qDebug() << "(*fun)(5,2) = " << (*fun)(5,3) << fun(5,3);
  18. return a.exec();
  19. }

何为二级指针

A(即B的地址)是指向指针的指针,称为二级指针,用于存放二级指针的变量称为二级指针变量.根据B的不同情况,二级指针又分为指向指针变量的指针和指向数组的指针。

解释来源于百度百科

嗯。。。

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. void mainA()
  4. {
  5. char *p[4] = { "calc","notepad","write","tasklist&pause" };
  6. //for (int i = 0; i < 4; i++)
  7. //{
  8. // system(p[i]);//下标的方式访问
  9. //}
  10. //for (int i = 0; i < 4; i++)
  11. //{
  12. // system(*(p+i));//下标的方式访问
  13. //}
  14. //轮询一个数组,需要一个指针,轮询一个指针数组,需要一个二级指针
  15. for (int **pp = p; pp < p + 4; pp++)
  16. {
  17. system(*pp);
  18. }
  19. }
  20. void run(char*p[4])//数组没有副本机制,传递的是地址:二级指针
  21. {
  22. printf("run=%d\n", sizeof(p));//4
  23. for (int **pp = p; pp < p + 4; pp++)
  24. {
  25. system(*pp);
  26. }
  27. }
  28. void main()
  29. {
  30. char *p[4] = { "calc","notepad","write","tasklist&pause" };
  31. printf("main=%d\n",sizeof(p));//16
  32. run(p);//4
  33. getchar();
  34. }
  35. //因为函数对于数组没有副本机制
  36. //数组作为参数退化为一个指针
  37. //指针作为参数会退化为一个二级指针

何为单向链表?

单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始;链表是使用指针进行构造的列表;又称为结点列表,因为链表是由一个个结点组装起来的;其中每个结点都有指针成员变量指向列表中的下一个结点;

列表是由结点构成,head指针指向第一个成为表头结点,而终止于最后一个指向NULL的指针。

解释来源于百度百科

so。。。

  1. package com.zjn.LinkAndQueue;
  2. /**
  3. * 自定义链表设计
  4. *
  5. * @author zjn
  6. *
  7. */
  8. public class MyLink {
  9. Node head = null; // 头节点
  10. /**
  11. * 链表中的节点,data代表节点的值,next是指向下一个节点的引用
  12. *
  13. * @author zjn
  14. *
  15. */
  16. class Node {
  17. Node next = null;// 节点的引用,指向下一个节点
  18. int data;// 节点的对象,即内容
  19. public Node(int data) {
  20. this.data = data;
  21. }
  22. }
  23. /**
  24. * 向链表中插入数据
  25. *
  26. * @param d
  27. */
  28. public void addNode(int d) {
  29. Node newNode = new Node(d);// 实例化一个节点
  30. if (head == null) {
  31. head = newNode;
  32. return;
  33. }
  34. Node tmp = head;
  35. while (tmp.next != null) {
  36. tmp = tmp.next;
  37. }
  38. tmp.next = newNode;
  39. }
  40. /**
  41. *
  42. * @param index:删除第index个节点
  43. * @return
  44. */
  45. public boolean deleteNode(int index) {
  46. if (index < 1 || index > length()) {
  47. return false;
  48. }
  49. if (index == 1) {
  50. head = head.next;
  51. return true;
  52. }
  53. int i = 1;
  54. Node preNode = head;
  55. Node curNode = preNode.next;
  56. while (curNode != null) {
  57. if (i == index) {
  58. preNode.next = curNode.next;
  59. return true;
  60. }
  61. preNode = curNode;
  62. curNode = curNode.next;
  63. i++;
  64. }
  65. return false;
  66. }
  67. /**
  68. *
  69. * @return 返回节点长度
  70. */
  71. public int length() {
  72. int length = 0;
  73. Node tmp = head;
  74. while (tmp != null) {
  75. length++;
  76. tmp = tmp.next;
  77. }
  78. return length;
  79. }
  80. /**
  81. * 在不知道头指针的情况下删除指定节点
  82. *
  83. * @param n
  84. * @return
  85. */
  86. public boolean deleteNode11(Node n) {
  87. if (n == null || n.next == null)
  88. return false;
  89. int tmp = n.data;
  90. n.data = n.next.data;
  91. n.next.data = tmp;
  92. n.next = n.next.next;
  93. System.out.println("删除成功!");
  94. return true;
  95. }
  96. public void printList() {
  97. Node tmp = head;
  98. while (tmp != null) {
  99. System.out.println(tmp.data);
  100. tmp = tmp.next;
  101. }
  102. }
  103. public static void main(String[] args) {
  104. MyLink list = new MyLink();
  105. list.addNode(5);
  106. list.addNode(3);
  107. list.addNode(1);
  108. list.addNode(2);
  109. list.addNode(55);
  110. list.addNode(36);
  111. System.out.println("linkLength:" + list.length());
  112. System.out.println("head.data:" + list.head.data);
  113. list.printList();
  114. list.deleteNode(4);
  115. System.out.println("After deleteNode(4):");
  116. list.printList();
  117. }
  118. }
时间 代码行数 这周所花的时间 学到的知识点简介 目前比较疑惑的问题
3/2-3/19 35 两天 通过代码读取文件里的数据,并且在屏幕上打印 为什么文件的使用还要进行关闭
3/9-3/19 65 三十分钟 没有学到任何知识点 想知道指针与数组之间的内在联系
3/19-3/22 186 五个小时 二维数组的用法加上二分法找元素 需要多打代码多多练习
3/22-3/28 31 一天 字符串的使用 数组排序的内部原理
3/28-4/5 108 一天 指针初步 行参与实参如何相互影响
4/5-4/11 62 一天 熟练指针 指针实际应用的问题
4/11-4/19 182 两天 会使用struct进行编码 为什么不能用赋值表达式直接对数组赋值
4/19- 4/26 126 三天 对结构体的使用更加得心应手 结构定义形式的具体影响是什么
5/6-5/10 189 三天 宏定义的初步体验 如何使用函数递归解决问题

2019春第十一周作业Compile Summarize的更多相关文章

  1. 2019春第十周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够对C语言的编写更加得心应手 这个作业在那个具体方面帮助我实现目标 结构体更进一步 参考文献与网址 C语言 ...

  2. 2019春第八周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 指针对于高阶题目的做法 参考文献与 ...

  3. 2019春第七周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 指针对于基础题目的做法 参考文献与 ...

  4. 2019春第六周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 对指针的使用更加得心应手 参考文献与网址 C语 ...

  5. 2019春第五周作业Compile Summarize

    这个作业属于哪个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够精通关于数组内部运作原理 这个作业在哪个具体方面帮助我实现目标 如何输出一行的连续字符 参考文献与网址 ...

  6. 2019春第十二周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 这里 我在这个课程的目标是 能按自己的想法解出题目 这个作业在那个具体方面帮助我实现目标 能朝着软件工程师方向发展 参考文献与网址 C语言 ...

  7. 2019春第九周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 这里 我在这个课程的目标是 能更加进一步的够熟练掌握指针的用法 这个作业在那个具体方面帮助我实现目标 能解更多的题 参考文献与网址 C语言 ...

  8. 2019-2020-1 20199329《Linux内核原理与分析》第十一周作业

    <Linux内核原理与分析>第十一周作业 一.本周内容概述: 学习linux安全防护方面的知识 完成实验楼上的<ShellShock 攻击实验> 二.本周学习内容: 1.学习& ...

  9. 2017-2018-2 20179205《网络攻防技术与实践》第十一周作业 SQL注入攻击与实践

    <网络攻防技术与实践>第十一周作业 SQL注入攻击与实践 1.研究缓冲区溢出的原理,至少针对两种数据库进行差异化研究 缓冲区溢出原理   在计算机内部,输入数据通常被存放在一个临时空间内, ...

随机推荐

  1. Ansbile实战经验

    一.相关用法: 1.执行shell 获取web组里得eth0接口信息 ansible web -a "ifconfig eth0" 2.执行ifconfig eth0 命令,ans ...

  2. Thymeleaf 模板引擎简介

    目录 Thymeleaf 模板引擎 官方文档下载 Hello World 新建应用 后台控制器 前端页面 浏览器访问测试 Thymeleaf 模板引擎1.Thymeleaf 是 Web 和独立环境的现 ...

  3. mysql查看内存使用情况

    SELECT table_name '表名称',table_rows '数据量(万)',data_size '磁盘(G)'FROM (SELECT table_name table_name, tru ...

  4. Redis---系统学习

    1.安装Redis Docker 2.查看Redis配置 进入Docker中的Redis容器: 进入启动命令目录:cd /usr/local/bin/ 启动redis客户端:./redis-cli c ...

  5. 使用idea对XML的增删改查

    XML:是一种可扩展标记性的语言,与java语言无关,它可以自定义标签. 1.首先需要到导入Dom4j架包,与自己所时候的ide关联 2.编写自己的xml文件,入上图所示(里面的所有元素及元素中的属性 ...

  6. 事物 @Transactional

    转载:http://www.cnblogs.com/kristain/articles/2038397.html 一.什么是事务 事务是访问数据库的一个操作序列,数据库应用系统通过事务集来完成对数据库 ...

  7. Java——类的继承、访问控制

    [继承] <1>Java只支持单继承,不支持多继承. <2>继承父类的私有成员变量,只有所有权,没有使用权.   [继承中的构造方法]

  8. codevs 3060 抓住那头奶牛 x

    3060 抓住那头奶牛 USACO  时间限制: 1 s  空间限制: 16000 KB  题目等级 : 黄金 Gold   题目描述 Description 农夫约翰被告知一头逃跑奶牛的位置,想要立 ...

  9. 【bzoj1179】[Apio2009]Atm

    *题目描述: *输入: 第一行包含两个整数N.M.N表示路口的个数,M表示道路条数.接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路的起点和终点的路口编号.接下来 ...

  10. Linux日志管理系统rsyslog

    一.日志的概念 什么是日志?日志就是历史事件.历史事件包括时间.地点.人物.时间.这个是生活中所说的日志很好理解.在Linux中也有类似的服务,它主要作用就是记录Linux系统的历史事件,包括什么时间 ...