Dynamic Data Structures

1. 问题:给定集合S,是否能找到subset使其加和为1000

方法一:用n bits表示集合中的所有元素,每一个bit代表集合中的一个元素,如果bit取值为1则A[i]属于subset,反之不属于

如:A[ ]={1,2,3,5}, 则1100表示subset={1,2}

共有2n种情况,故而时间复杂度为O(2n)

方法二:递归

subset(A,n,k)

若第n个value (A[n-1]) 是solution的一部分,则前n-1个value总和为k – A[n-1]

若不是则总和仍为k

base case: k=0 (return True); n=0(unsolvable if k>0, return False,此时没有可选element)

最坏的情况下依然要遍历所有,故而时间复杂度依然为O(2n) (C1 = 2, Cn = 2 + 2·Cn-1

2. 0b1101, 0b means which is based on 2 (binary system)

0x3AF1, 0x measn which is based on 16 (hexadecimal  system)   0~9, A~F

decimal system is based on 10

3. 74=64+8+2=0b1001010

0x2D=2*16+13=45

0b1011 1110 0010 1001=0xBE29

0x12D=0b100101101

4. memory的存储总是将更高的memory放在上面,一个变量被声明后,操作系统会在memory中存储相应的字节数量

其中character为1 byte,int和float为4 bytes,double为8 bytes

如果我们声明了一个变量k, 则存储k的地方为&k

5. %p为地址的占位符,存放pointer value

6. scanf中一定要明确可以input的变量类型,且需要变量地址,如:

1 #include <stdio.h>
2 3 int answer;
4 printf("Enter your answer: ");
5 scanf("%d", &answer);

 7. pointer是一种特殊形式的变量,用于存储另一个变量的地址。pointer所需要占用的内存又电脑本身的功能结构决定

如64位电脑需要8memory cells,理论上可存储264 bytes,但实际内存由CPU限制

8. *被用来进入pointer所指向的目标,pointer将被限制只能指向一种类型的变量

1 int *p; int *q; // this is how pointers are declared
2 int a[5];
3 int x = 10, y;
4 
5  p = &x;      // p now points to x
6 *p = 20;      // whatever p points to is now equal to 20
7  y = *p;      // y is now equal to whatever p points to
8  p = &a[2];   // p points to an element of array a[]
9  q = p;       // q and p now point to the same thing

 9. exercise: What is the output of the following program?

 1  #include <stdio.h>
 2
 3  int main(void) {
 4     int *ptr1, *ptr2;
 5     int i = 10, j = 20;
 6
 7     ptr1 = &i;
 8     ptr2 = &j;
 9
10     *ptr1 = *ptr1 + *ptr2;
11     ptr2 = ptr1;
12     *ptr2 = 2 * (*ptr2);
13     printf("Val = %d\n", *ptr1 + *ptr2);
14     return 0;
15  }

 

10. pointer作用:如想对两个数利用一个临时辅助变量进行数值交换,由于这种操作只能在function内有效(local),pointer可以帮忙改变变量实际的数值

11. 由于C语言知道pointer所指向的变量,故而它可以计算出下一个目标的位置。如若一个pointer被声明为T *p (T为变量类型),若pointer现在指向的地址为A,执行p=p+k,p的值将被修改为A+k*sizeof(T)

12. array中的pointer

决定array中的第一个元素以及最后一个元素,设定一个动态pointer指向array中的第一个元素,利用循环使pointer逐一向后遍历,即

 

1 int *p;
2 int a[6];
3 for {p = &a[0];p < &a[6];p++}
4     printf("%2d",*p) 

a[i]=*(a+1), *a指向array[0]

13. 利用命令行指令时,一开始输入的总是string格式,但是可以convert成别的形式(atoi(char *s) converts string to int)

argc存储command-line arguments的数量+1(因为包含文件名)

argv存储内容

14. double pointer: 指向pointer的pointer

posted on 2019-10-10 10:19  Eleni  阅读(349)  评论(1编辑  收藏  举报

导航