欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

北郵計算機考研復(fù)試題的C語言解答精選

 更新時間:2015年08月16日 09:49:12   作者:低調(diào)小一  
這篇文章主要介紹了北郵計算機考研復(fù)試題目的C語言解答精選,選自2012年的一些基礎(chǔ)的上機題目,需要的朋友可以參考下

二進制數(shù)
題目

    題目描述: 
      大家都知道,數(shù)據(jù)在計算機里中存儲是以二進制的形式存儲的。 
      有一天,小明學(xué)了C語言之后,他想知道一個類型為unsigned int 類型的數(shù)字,存儲在計算機中的二進制串是什么樣子的。 
      你能幫幫小明嗎?并且,小明不想要二進制串中前面的沒有意義的0串,即要去掉前導(dǎo)0。 
    輸入: 
    第一行,一個數(shù)字T(T<=1000),表示下面要求的數(shù)字的個數(shù)。 
    接下來有T行,每行有一個數(shù)字n(0<=n<=10^8),表示要求的二進制串。 
    輸出: 
    輸出共T行。每行輸出求得的二進制串。 
    樣例輸入: 
    5 
    23 
    535 
    2624 
    56275 
    989835 
    樣例輸出: 
    10111 
    1000010111 
    101001000000 
    1101101111010011 
    11110001101010001011 


ac代碼
沒什么可說的,簡單的機制轉(zhuǎn)換,連大數(shù)除法都沒考察!

  #include <stdio.h> 
  #include <string.h> 
  #include <stdlib.h> 
    
  struct stack 
  { 
    int top; 
    int data[100]; 
  }; 
    
  void convert_to_binary(struct stack *s, unsigned long int d) 
  { 
    s->top = 0; 
    
    while (d) { 
      s->data[s->top ++] = d % 2; 
      d /= 2; 
    } 
    
    while (s->top) { 
      printf("%d", s->data[-- s->top]); 
    } 
    printf("\n"); 
  } 
    
  int main() 
  { 
    int i, n; 
    unsigned long int d; 
    struct stack *s = (struct stack*)malloc(sizeof(struct stack)); 
    
    while (scanf("%d", &n) != EOF) { 
      for (i = 0; i < n; i ++) { 
        scanf("%ld", &d); 
        if (d != 0) { 
          convert_to_binary(s, d); 
        }else { 
          printf("0\n"); 
        } 
      } 
    } 
    
    return 0; 
  } 

    /**************************************************************
        Problem: 1473
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:10 ms
        Memory:904 kb
    ****************************************************************/ 

二叉排序樹
題目

    題目描述: 
            二叉排序樹,也稱為二叉查找樹??梢允且活w空樹,也可以是一顆具有如下特性的非空二叉樹: 
     
            1. 若左子樹非空,則左子樹上所有節(jié)點關(guān)鍵字值均不大于根節(jié)點的關(guān)鍵字值; 
            2. 若右子樹非空,則右子樹上所有節(jié)點關(guān)鍵字值均不小于根節(jié)點的關(guān)鍵字值; 
            3. 左、右子樹本身也是一顆二叉排序樹。 
     
      現(xiàn)在給你N個關(guān)鍵字值各不相同的節(jié)點,要求你按順序插入一個初始為空樹的二叉排序樹中,每次插入后成功后,求相應(yīng)的父親節(jié)點的關(guān)鍵字值,如果沒有父親節(jié)點,則輸出-1。 
    輸入: 
    輸入包含多組測試數(shù)據(jù),每組測試數(shù)據(jù)兩行。 
    第一行,一個數(shù)字N(N<=100),表示待插入的節(jié)點數(shù)。 
    第二行,N個互不相同的正整數(shù),表示要順序插入節(jié)點的關(guān)鍵字值,這些值不超過10^8。 
    輸出: 
    輸出共N行,每次插入節(jié)點后,該節(jié)點對應(yīng)的父親節(jié)點的關(guān)鍵字值。 
    樣例輸入: 
    5 
    2 5 1 3 4 
    樣例輸出: 
    -1 
    2 
    2 
    5 
    3 


ac代碼
沒什么思路,最簡單的構(gòu)建二叉排序樹而已

   

 #include <stdio.h> 
  #include <stdlib.h> 
  #include <string.h> 
    
  struct btree 
  { 
    struct btree *lchild, *rchild; 
    unsigned long int data; 
  }; 
    
  struct btree* create_btree(struct btree *t, unsigned long int d, unsigned long int parent); 
    
  int main() 
  { 
    int i, n; 
    unsigned long int d; 
    struct btree *t; 
    
    while (scanf("%d", &n) != EOF) { 
      t = NULL; 
      for (i = 0; i < n; i ++) { 
        scanf("%ld", &d); 
        t = create_btree(t, d, -1); 
      } 
    } 
    
    return 0; 
  } 
    
  struct btree* create_btree(struct btree *t, unsigned long int d, unsigned long int parent) 
  { 
    if (t == NULL) { 
      t = (struct btree *)malloc(sizeof(struct btree)); 
      t->data = d; 
      t->lchild = NULL; 
      t->rchild = NULL; 
      printf("%ld\n", parent);     
    }else if(t->data > d) { 
      t->lchild = create_btree(t->lchild, d, t->data); 
    }else if(t->data < d) { 
      t->rchild = create_btree(t->rchild, d, t->data); 
    }else { 
      exit(EXIT_FAILURE); 
    } 
    
    return t; 
  } 

       
    /**************************************************************
        Problem: 1467
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:10 ms
        Memory:904 kb
    ****************************************************************/ 


矩陣冪
題目

    題目描述: 
    給定一個n*n的矩陣,求該矩陣的k次冪,即P^k。 
    輸入: 
    輸入包含多組測試數(shù)據(jù)。 
    數(shù)據(jù)的第一行為一個整數(shù)T(0<T<=10),表示要求矩陣的個數(shù)。 
    接下來有T組測試數(shù)據(jù),每組數(shù)據(jù)格式如下:  
    第一行:兩個整數(shù)n(2<=n<=10)、k(1<=k<=5),兩個數(shù)字之間用一個空格隔開,含義如上所示。 
    接下來有n行,每行n個正整數(shù),其中,第i行第j個整數(shù)表示矩陣中第i行第j列的矩陣元素Pij且(0<=Pij<=10)。另外,數(shù)據(jù)保證最后結(jié)果不會超過10^8。 
    輸出: 
    對于每組測試數(shù)據(jù),輸出其結(jié)果。格式為: 
    n行n列個整數(shù),每行數(shù)之間用空格隔開,注意,每行最后一個數(shù)后面不應(yīng)該有多余的空格。 
    樣例輸入: 
    3 
    2 2 
    9 8 
    9 3 
    3 3 
    4 8 4 
    9 3 0 
    3 5 7 
    5 2 
    4 0 3 0 1 
    0 0 5 8 5 
    8 9 8 5 3 
    9 6 1 7 8 
    7 2 5 7 3 
    樣例輸出: 
    153 96 
    108 81 
    1216 1248 708 
    1089 927 504 
    1161 1151 739 
    47 29 41 22 16 
    147 103 73 116 94 
    162 108 153 168 126 
    163 67 112 158 122 
    152 93 93 111 97 

ac代碼
這個也是挺簡單的,就是個矩陣乘法,三個for循環(huán)即可

 

  #include <stdio.h> 
  #include <stdlib.h> 
  #include <string.h> 
    
  #define LEN 15 
    
  int a[LEN][LEN], b[LEN][LEN], c[LEN][LEN]; 
    
  void multiplay_matrix(); 
    
    
  int main() 
  { 
    int t, n, k, i, j, d; 
    
    scanf("%d", &t); 
    while (t --) { 
      // 接收矩陣 
      scanf("%d %d", &n, &k); 
      for (i = 0; i < n; i ++) { 
        for (j = 0; j < n; j ++) { 
          scanf("%d", &d); 
          a[i][j] = d; 
          b[i][j] = d; 
          c[i][j] = d; 
        } 
      } 
    
      // 矩陣的冪 
      if (k != 1) { 
        multiplay_matrix(k, n); 
      } 
    
      for (i = 0; i < n; i ++) { 
        for (j = 0; j < n; j ++) { 
          if (j == n - 1) { 
            printf("%d\n", c[i][j]); 
          }else { 
            printf("%d ", c[i][j]); 
          } 
        } 
      } 
    } 
    
    return 0; 
  } 
    
  void multiplay_matrix(int k, int n) 
  { 
    int i, j, h, data; 
    k --; 
    while (k --) { 
      for (i = 0; i < n; i ++) { 
        for (j = 0; j < n; j ++) { 
          for (h = data = 0; h < n; h ++) { 
            data += b[i][h] * a[h][j]; 
          } 
          c[i][j] = data; 
        } 
      } 
      for (i = 0; i < n; i ++) { 
        for (j = 0; j < n; j ++) { 
          b[i][j] = c[i][j]; 
        } 
      } 
    } 
  } 

    /**************************************************************
        Problem: 1474
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:10 ms
        Memory:912 kb
    ****************************************************************/ 


IP數(shù)據(jù)包解析
題目

201581695025979.png (521×497)

    頭部長度單位為4字節(jié)。 
      你的任務(wù)是,簡要分析輸入數(shù)據(jù)中的若干個TCP數(shù)據(jù)段的頭部。 詳細要求請見輸入輸出部分的說明。 
    輸入: 
    第一行為一個整數(shù)T,代表測試數(shù)據(jù)的組數(shù)。 
    以下有T行,每行都是一個TCP數(shù)據(jù)包的頭部分,字節(jié)用16進制表示,以空格隔開。數(shù)據(jù)保證字節(jié)之間僅有一個空格,且行首行尾沒有多余的空白字符。 
    保證輸入數(shù)據(jù)都是合法的。 
    輸出: 
    對于每個TCP數(shù)據(jù)包,輸出如下信息: 
    Case #x,x是當(dāng)前測試數(shù)據(jù)的序號,從1開始。 
    Total length = L bytes,L是整個IP數(shù)據(jù)包的長度,單位是1字節(jié)。 
    Source = xxx.xxx.xxx.xxx,用點分十進制輸出源IP地址。輸入數(shù)據(jù)中不存在IPV6數(shù)據(jù)分組。 
    Destination = xxx.xxx.xxx.xxx,用點分十進制輸出源IP地址。輸入數(shù)據(jù)中不存在IPV6數(shù)據(jù)分組。 
    Source Port = sp,sp是源端口號。 
    Destination Port = dp,dp是目標(biāo)端口號。 
    對于每個TCP數(shù)據(jù)包,最后輸出一個多余的空白行。 
    具體格式參見樣例。 
    請注意,輸出的信息中,所有的空格、大小寫、點符號、換行均要與樣例格式保持一致,并且不要在任何數(shù)字前輸出多余的前導(dǎo)0,也不要輸出任何不必要的空白字符。 
    樣例輸入: 
    2 
    45 00 00 34 7a 67 40 00 40 06 63 5a 0a cd 0a f4 7d 38 ca 09 cd f6 00 50 b4 d7 ae 1c 9b cf f2 40 80 10 ff 3d fd d0 00 00 01 01 08 0a 32 53 7d fb 5e 49 4e c8 
    45 00 00 c6 56 5a 40 00 34 06 e0 45 cb d0 2e 01 0a cd 0a f4 00 50 ce 61 e1 e9 b9 ee 47 c7 37 34 80 18 00 b5 81 8f 00 00 01 01 08 0a 88 24 fa c6 32 63 cd 8d 
    樣例輸出: 
    Case #1 
    Total length = 52 bytes 
    Source = 10.205.10.244 
    Destination = 125.56.202.9 
    Source Port = 52726 
    Destination Port = 80 
     
    Case #2 
    Total length = 198 bytes 
    Source = 203.208.46.1 
    Destination = 10.205.10.244 
    Source Port = 80 
    Destination Port = 52833 

ac代碼
注意取源端口號和目的端口號時需要注意ip頭部長度的判斷,IHL,其它就沒神馬難度了

  #include <stdio.h> 
  #include <stdlib.h> 
  #include <string.h> 
    
  #define LEN 1000 
    
  int change_tint(char *str, int begin, int num) 
  { 
    int i; 
    char *temp = (char *)malloc(sizeof(char) * (num + 1)); 
    
    for(i = 0; i < num; i ++) { 
      temp[i] = str[begin + i]; 
    } 
    temp[i] = '\0'; 
    
    return strtol(temp, NULL, 16); 
  } 
    
  void ip_field(char *str, int begin, int num) 
  { 
    int i, flag, ip; 
    for (i = 0, flag = 1; i < num; i += 2) { 
      ip = change_tint(str, begin + i, 2); 
      printf("%d", ip); 
      if (flag <= 3) { 
        printf("."); 
        flag ++; 
      } 
    } 
    printf("\n"); 
  } 
    
    
  int main() 
  { 
    int index, i, j, n, length, ihl; 
    char ipstr[LEN], temp[LEN]; 
    
    while (scanf("%d\n", &n) != EOF) { 
      if (n != 0) { 
        for (index = 1; index <= n; index ++) { 
          memset(ipstr, 0, sizeof(ipstr)); 
          memset(temp, 0, sizeof(temp));  
          gets(temp); 
          // 去除空格 
          for (i = j = 0, length = strlen(temp); i < length; i ++) { 
            if (temp[i] != ' ') { 
              ipstr[j ++] = temp[i]; 
            } 
          } 
          ipstr[j] = '\0'; 
    
          // 當(dāng)前測試數(shù)據(jù)的序號 
          printf("Case #%d\n", index); 
    
          // 整個ip數(shù)據(jù)包的長度 
          length = change_tint(ipstr, 4, 4); 
          printf("Total length = %d bytes\n", length); 
    
          // 源ip地址和目的ip地址 
          printf("Source = "); 
          ip_field(ipstr, 24, 8); 
          printf("Destination = "); 
          ip_field(ipstr, 32, 8); 
    
          // 源端口號和目的端口號 
          ihl = change_tint(ipstr, 1, 1) * 4 * 2; 
          printf("Source Port = %d\n", change_tint(ipstr, ihl, 4)); 
          printf("Destination Port = %d\n", change_tint(ipstr, ihl + 4, 4)); 
          printf("\n"); 
        } 
      } 
    } 
    return 0; 
  } 

       
    /**************************************************************
        Problem: 1475
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:10 ms
        Memory:908 kb
    ****************************************************************/ 

相關(guān)文章

  • C語言求矩陣主對角線元素及副對角線元素之和

    C語言求矩陣主對角線元素及副對角線元素之和

    這篇文章主要介紹了C語言求矩陣主對角線元素及副對角線元素之和實例,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • C++ inline內(nèi)聯(lián)函數(shù)詳解

    C++ inline內(nèi)聯(lián)函數(shù)詳解

    這篇文章主要介紹了C++ inline內(nèi)聯(lián)函數(shù)詳解,有感興趣的同學(xué)可以借鑒參考下
    2021-02-02
  • C語言常用庫函數(shù)的使用及模擬實現(xiàn)詳解例舉

    C語言常用庫函數(shù)的使用及模擬實現(xiàn)詳解例舉

    C語言庫函數(shù)是把自定義函數(shù)放到庫里,是別人把一些常用到的函數(shù)編完放到一個文件里,供程序員使用,下面讓我們一起來詳細了解它
    2022-04-04
  • MFC中exe圖標(biāo)修改的方法

    MFC中exe圖標(biāo)修改的方法

    修改窗口標(biāo)題圖標(biāo)可通過導(dǎo)入圖標(biāo),然后在CMainFrame.:OnCreate函數(shù)中加載圖標(biāo)即可, 代碼如下:
    2013-04-04
  • 一篇文章帶你入門C語言:操作符

    一篇文章帶你入門C語言:操作符

    這篇文章主要介紹了C語言中的運算符,文中講解非常詳細,適合初學(xué)小白進行學(xué)習(xí),想入門C語言的朋友不妨了解下,希望能給你帶來幫助
    2021-08-08
  • C++使用動態(tài)內(nèi)存分配的原因解說

    C++使用動態(tài)內(nèi)存分配的原因解說

    這篇文章主要介紹了C++使用動態(tài)內(nèi)存分配的原因解說,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • c語言快速排序算法示例代碼分享

    c語言快速排序算法示例代碼分享

    快速排序使用分治法(Divide and conquer)策略來把一個串行(list)分為兩個子串行(sub-lists)
    2014-02-02
  • C語言實現(xiàn)父進程主動終止子進程的方法總結(jié)

    C語言實現(xiàn)父進程主動終止子進程的方法總結(jié)

    一般的情況,子進程自己運行完后,執(zhí)行exit 或者return 后,父進程wait.  waitpid收回子進程,但子進程是一個循環(huán)等待狀態(tài)不主動退出,父進程可以采用文中介紹的幾種方法,需要的朋友可以參考下
    2023-10-10
  • C語言實現(xiàn)三子棋(井字棋)算法

    C語言實現(xiàn)三子棋(井字棋)算法

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)三子棋(井字棋)算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 淺談C++ IO流

    淺談C++ IO流

    這篇文章主要介紹了C++ IO流的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下
    2020-08-08

最新評論