日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MTK笔试1题~

發布時間:2023/12/20 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MTK笔试1题~ 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這個題目是前幾天一個好友分享給我的,但是因為時間原因沒有及時寫成文章。

這是他參加MTK筆試的題目

題目如下:

網友提供的代碼如下:

#include?"stdio.h"typedef?struct?n{int?data;struct?n*?next;struct?n*?pre; }*pnode;int?main(){pnode?head?=?(pnode)malloc(sizeof(struct?n)?);pnode?preNode?=?head?;int?tmpVal;while(1){scanf("%d",&tmpVal);pnode?node?=?(pnode)malloc(sizeof(struct?n));node->data?=?tmpVal;node->next?=?NULL;node->pre?=?preNode;preNode->next?=?node;preNode?=?node;if(getchar()?==?'\n'){break;}}int?willbeadd;scanf("%d",&willbeadd);pnode?addNode?=?(pnode)malloc(sizeof(struct?n));addNode->data?=?willbeadd;//?這兩行一開始沒寫,懷疑是第一個測試用例卡在這了addNode->next?=?NULL;addNode->pre?=?NULL;pnode?cur?=?head->next;pnode?pre02?=?head;while(cur?!=?NULL?&&?cur->data?<?addNode->data){pre02?=?pre02->next;cur?=?cur->next;}if(cur?!=?NULL){addNode->next?=?cur;addNode->pre?=?pre02;cur->pre?=?addNode;pre02->next?=?addNode;}else{pre02->next?=?addNode;addNode->pre?=?pre02;}cur?=?head->next;while(cur->next?!=?NULL){printf("%d?",cur->data);cur?=?cur->next;}printf("%d",cur->data);cur?=?head;pnode?nextNode?=?cur->next;while(cur?!=?NULL){free(cur);cur?=?nextNode;if(nextNode?!=?NULL){nextNode?=?nextNode->next;}}return?0; }

然后,我運行了下,發現有問題

輸入 5 的時候,竟然卡死在這里不動了。

我本來以為程序有問題了,后面仔細看來下,應該是中文回車和英文回車的原因。

如果修改成英文輸入是沒有問題的

先解釋下這個程序,前面賦值就沒有啥好說的了,關鍵是查找的位置

在腦子里面要有一個雙鏈表的圖

如果向一個雙鏈表中插入數據,我們需要這樣操作

向鏈表中插入數據的核心代碼如下

/*找到位置,把新數據插入鏈表中*/ while(cur?!=?NULL?&&?cur->data?<?addNode->data){pre02?=?pre02->next;cur?=?cur->next; }if(cur?!=?NULL){/*如果找到的位置在中間*/addNode->next?=?cur;addNode->pre?=?pre02;cur->pre?=?addNode;pre02->next?=?addNode; }else{/*如果位置在雙向鏈表的最后面*/pre02->next?=?addNode;addNode->pre?=?pre02; }

然后之后的代碼就是打印輸出和釋放內存了。

但是有點問題的是,因為這個題目沒有題目的鏈接,不能直接驗證寫的答案是否完全正確,讀者們可以看看這份代碼,如果代碼有問題,歡迎評論指正。


推薦閱讀:

專輯|Linux文章匯總

專輯|程序人生

專輯|C語言

我的知識小密圈

關注公眾號,后臺回復「1024」獲取學習資料網盤鏈接。

歡迎點贊,關注,轉發,在看,您的每一次鼓勵,我都將銘記于心~

嵌入式Linux

微信掃描二維碼,關注我的公眾號

總結

以上是生活随笔為你收集整理的MTK笔试1题~的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。