• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            X-Coder

            Kim4Apple
            posts - 1, comments - 0, trackbacks - 0, articles - 2

            筆試題 A (轉)

            Posted on 2008-09-24 03:12 Kim4Apple 閱讀(74) 評論(0)  編輯 收藏 引用
            一、如何判斷一個單鏈表是有環的?(注意不能用標志位,最多只能用兩個額外指針) struct node { char val; node* next;} bool check(const node* head) {} //return false : 無環;true: 有環 一種O(n)的辦法就是(搞兩個指針,一個每次遞增一步,一個每次遞增兩步,如果有環的話兩者必然重合,反之亦然): bool check(const node* head) { if(head==NULL) return false; node *low=head, *fast=head->next; while(fast!=NULL && fast->next!=NULL) { low=low->next; fast=fast->next->next; if(low==fast) return true; } return false; } 二、刪除一個單項鏈表的最中間的元素,要求時間盡可能短(不能使用兩次循環) struct link { int data; struct link *next; }; void delMiddle(link *head) { if(head == NULL) return; else if(head->next == NULL) { delete head; return; } else { link *low = head; link *fast = head->next; while(fast != NULL && fast->next != NULL) { fast = fast->next->next; if(fast == NULL) break; low = low->next; } link *temp = low->next; low->next = low->next->next; delete temp; } } int main() { struct link *head,*l; struct link *s; head = (link*)malloc(sizeof(link)); head->data=0; head->next = NULL; l = head; for(int i=1; i<9; i++) { s = (link*)malloc(sizeof(link)); s->data = i; s->next = NULL; l->next= s; l = l->next; } print(head); delMiddle(head); print(head); return 0; } 三、輸入n,求一個n*n矩陣,規定矩陣沿45度線遞增(威盛) /** * 得到如下樣式的二維數組 * zigzag(jpeg編碼里取象素數據的排列順序) * * 0, 1, 5, 6,14,15,27,28, * 2, 4, 7,13,16,26,29,42, * 3, 8,12,17,25,30,41,43, * 9,11,18,24,31,40,44,53, * 10,19,23,32,39,45,52,54, * 20,22,33,38,46,51,55,60, * 21,34,37,47,50,56,59,61, * 35,36,48,49,57,58,62,63 */ void zigzag(int n) { int **a =(int**) malloc(n*sizeof(int *)); //分配空間 if(NULL == a) return ; int i; for(i = 0; i < n; i++) { if((a[i] =(int*) malloc(n * sizeof(int))) == NULL) { while(--i>=0) free(a[i]); free(a); return; } } bool flag = false; //這個標志位用來判斷是從45度角生成還是225度角生成 int count = 0; for(i=0; i=0; r--) { a[r][i-r] = count; count++; } flag = true; } } for(i=n-1; i>=0; i--) //生成的是下半部分的數據 { // cout<=0; r--) { cout<<"ddd"<>n; zigzag(n); return 0; } 網上還有一個人寫了一個比較巧的算法: /** * 得到如下樣式的二維數組 * zigzag(jpeg編碼里取象素數據的排列順序) * * 0, 1, 5, 6,14,15,27,28, * 2, 4, 7,13,16,26,29,42, * 3, 8,12,17,25,30,41,43, * 9,11,18,24,31,40,44,53, * 10,19,23,32,39,45,52,54, * 20,22,33,38,46,51,55,60, * 21,34,37,47,50,56,59,61, * 35,36,48,49,57,58,62,63 */ #include int main() { int N; int s, i, j; int squa; scanf("%d", &N); /* 分配空間 */ int **a = malloc(N * sizeof(int *)); if(a == NULL) return 0; for(i = 0; i < N; i++) { if((a[i] = malloc(N * sizeof(int))) == NULL) { while(--i>=0) free(a[i]); free(a); return 0; } } /* 數組賦值 */ squa = N*N; for(i = 0; i < N; i++) for(j = 0; j < N; j++) { s = i + j; if(s < N) a[i][j] = s*(s+1)/2 + (((i+j)%2 == 0)? i : j); else { s = (N-1-i) + (N-1-j); a[i][j] = squa - s*(s+1)/2 - (N - (((i+j)%2 == 0)? i : j)); } } /* 打印輸出 */ for(i = 0; i < N; i++) { for(j = 0; j < N; j++) printf("%-6d", a[i][j]); printf("\n"); } return 0; } 四、打印1到1000的整數,不能使用流程控制語句(for,while,goto等)也不能使用遞歸 1. typedef struct _test{ static int a; _test(){ printf("%d\n",_test::a); a++; } }Test; int Test::a = 1; int main() { Test tt[1000]; return 0; } 2. #include #define B P,P,P,P,P,P,P,P,P,P #define P L,L,L,L,L,L,L,L,L,L #define L I,I,I,I,I,I,I,I,I,I,N #define I printf( "%3d ",i++) #define N printf( "\n ") int main() { int i = 1; B; } 或 #define A(x) x;x;x;x;x;x;x;x;x;x; int main () { int n = 1; A(A(A(printf ("%d ", n++)))); return 0; } 五、struct S { int i; int * p; }; void main() { S s; int * p = &s.i; p[0] = 4; p[1] = 3; s.p = p; s.p[1] = 1; s.p[0] = 2; } 問程序會在哪一行死掉。 (microsoft) 解: S s; int * p = &s.i; //s.i的地址存儲在p里 p[0] = 4; //修改了s.i p[1] = 3; //修改了s.p s.p = p; //s.p指向s.i s.p[1] = 1; //修改s.p本身 s.p[0] = 2; //s.p指向的是0x00000001,嘗試向這里寫,出錯 s.p[0] = 2; 時出錯 因為s.p存的是s.i的地址,s.p[1]為s.p,當s.p[1]=1時,s.p此時存放的是1了,而不是地址s.i,故在s.p[0] = 2時出錯. 此時相當于s.p=ox00000001;地址ox0000001 = 2;當然就出錯了 如果語句s.p[0] =2 先于s.p[1]=1則程序就不會出錯.此時語句相當于s.i=2;s.p=1; 六、題目描述: 1. int swap(int *x,int *y) { if(x==NULL | | y==NULL) return -1; *x += *y; *y = *x- *y; *x -= *y; return 1; } 請改錯,溢出已經考慮,不是錯誤 2. void foo(int *x, int *y) { *x += *y; *x += *y; } void fun(int *x, int *y) { *x += 2 * (*y); } 問兩個函數是否等價,能否互換 解答:第一題的函數是交換。但假如考慮x, y都是指向同一個變量,結果是這個變量的值為0. 第二題的兩個函數是有區別的,也考慮x,y是指向同一個變量.這樣第一個函數的結果是這個變量的4倍.但第二個函數的結果是變量的3倍.
            亚洲国产成人精品无码久久久久久综合| 伊人久久大香线焦综合四虎| 激情五月综合综合久久69| 久久久精品日本一区二区三区| 久久久久国产精品麻豆AR影院| 久久人妻AV中文字幕| 91精品国产乱码久久久久久| 久久97久久97精品免视看| 97久久国产综合精品女不卡| 成人a毛片久久免费播放| 久久久久av无码免费网| 91精品国产91久久久久久蜜臀| 久久精品综合网| 久久精品国产国产精品四凭| 无码AV波多野结衣久久| 久久综合伊人77777麻豆| 国产情侣久久久久aⅴ免费| 亚洲Av无码国产情品久久| 99精品久久久久久久婷婷| 久久久www免费人成精品| 久久人人爽人人爽AV片| 国产午夜久久影院| 九九久久自然熟的香蕉图片| 亚洲七七久久精品中文国产| 日本精品久久久久中文字幕8| 精品人妻伦九区久久AAA片69| 欧美午夜A∨大片久久| 久久国产V一级毛多内射| 久久亚洲综合色一区二区三区| 久久久精品人妻一区二区三区蜜桃| 久久久久99精品成人片三人毛片| 99久久婷婷国产一区二区| 久久国产精品-久久精品| 91精品国产综合久久婷婷| 无码伊人66久久大杳蕉网站谷歌| 亚洲精品午夜国产va久久| 欧美亚洲另类久久综合婷婷 | 久久久亚洲AV波多野结衣| 久久久综合香蕉尹人综合网| 欧洲性大片xxxxx久久久| 久久精品国产精品亜洲毛片|