成人免费网站视频,成人午夜免费av,依依成人综合视频,蜜桃视频m3u8在线观看

所在位置:大風車考試網 > 招聘筆試題 > 正文

騰訊校園招聘C語言筆試題和面試題答案

2024-05-20 10:06:51 大風車考試網

  下面這套筆試題是2015騰訊校園招聘C語言常考知識點,分享給大家了解。
  1. 輸入一個鏈表的頭結點,從尾到頭反過來輸出每個結點的值。鏈表結點定義如下:

  struct ListNode

  {

  int m_nKey;

  ListNode* m_pNext;

  };

  A: 遞歸方法逆序輸出,棧方法逆序輸出。

  (任意實現一種既可)

  void PrintListUsingRecursicve(pListNode head)

  {

  if(head!=NULL)

  {

  PrintListUsingRecursicve(head->m_pNext);

  printf("%d/n",head->m_nKey);

  }

  }

  void PrintListUsingStack(pListNode head)

  {

  Stack s;

  s.top=0;

  pListNode p=head;

  do{

  push(&s,p->m_nKey);

  p=p->m_pNext;

  }while(p!=NULL);本文由論文聯盟http://www.LWlm.COM收集整理

  while(!IsEmpty(&s))

  {

  printf("%d/n",pop(&s));

  }

  }

  2. 二元樹的深度

  題目:輸入一棵二元樹的根結點,求該樹的深度。從根結點到葉結點依次經過的結點(含根、葉結點)形成樹的一條路徑,最長路徑的長度為樹的深度。

  #include

  #include

  #include

  #include

  #define MAXLEN 100

  #define MAXNUM 10

  typedef int Tree[MAXLEN];

  Tree bt;

  int GetDeep(int i)

  {

  int l=0,r=0;

  if(bt[i*2]!=-1)

  {

  l=GetDeep(i*2)+1;

  }

  if(bt[i*2+1]!=-1)

  {

  r= GetDeep(i*2+1)+1;

  }

  return l>r?l:r;

  }

  int main()

  {

  int i=0;

  memset(bt,-1,sizeof(bt));

  for(i=1;i<=MAXNUM;i++)

  bt[i]=i;

  bt[(i-1)*2]=i*2;

  printf("%d /n",GetDeep(1));

  return 0;

  }

  3. 整數的二進制表示中1的個數

  題目:輸入一個整數,求該整數的二進制表達中有多少個1。例如輸入10,由于其二進制表示為1010,有兩個1,因此輸出2。

  (關鍵是能不能想到后面的那個方法,只要想到這個方法既可)

  int Bit1inInt(int i)

  {

  int result=0;

  do{

  result+=i&1;

  }while(i=i>>1);

  return result;

  }

  4. 從上往下遍歷二元樹

  題目:輸入一顆二元樹,從上往下按層打印樹的每個結點,同一層中按照從左往右的順序打印。

  (先序,中序,后序三種方式實現)

  如果從上往下,從左到右的話只有一種遍歷的方式:廣度優先遍歷。

  #include

  #include

  #include

  #include

  #define MAXLEN 100

  #define MAXNUM 10

  typedef int Tree[MAXLEN];

  Tree bt;

  typedef struct queue

  {

  int begin,end;

  int space[MAXLEN];

  }Queue;

  int main()

  {

  int i=0;

  memset(bt,-1,sizeof(bt));

  for(i=1;i<=MAXNUM;i++)

  bt[i]=i;

  Queue qe;

  qe.begin=0;qe.end =0;

  qe.space[qe.end++]=bt[1];

  while(qe.begin!=qe.end)

  {

  if(bt[2*qe.space[qe.begin]]!=-1)//lchild

  {

  qe.space[qe.end++]=bt[2*qe.space[qe.begin]];

  }

  if(bt[2*qe.space[qe.begin]+1]!=-1)//rchild

  {

  qe.space[qe.end++]=bt[2*qe.space[qe.begin]+1];

  }

  qe.begin++;

  }

  printf("--------------------/n");

  for(i=0;i

  printf("%d ",qe.space[i]);

  return 0;

  }

  先序,中序,后序三種方式的只是遍歷二元樹

  typedef int Tree[MAXLEN];

  Tree bt;

  void PreOrderTraverse(int i)

  {

  if(bt[i]==-1) {return ;}

  printf("%d ",bt[i]);

  PreOrderTraverse(i*2);//lchild

  PreOrderTraverse(i*2+1);//rchild

  }

  void InOrderTraverse(int i)

  {

  if(bt[i]==-1) {return ;}

  InOrderTraverse(i*2);//lchild

  printf("%d ",bt[i]);

  InOrderTraverse(i*2+1);//rchild

  }

  void PostOrderTraverse(int i)

  {

  if(bt[i]==-1) {return ;}

  PostOrderTraverse(i*2);//lchild

  PostOrderTraverse(i*2+1);//rchild

  printf("%d ",bt[i]);

  }

  int main()

  {

  int i=0;

  memset(bt,-1,sizeof(bt));

  for(i=1;i<=MAXNUM;i++)

  bt[i]=i;

  printf("/n---------------/n");

  PreOrderTraverse(1);

  printf("/n---------------/n");

  InOrderTraverse(1);

  printf("/n---------------/n");

  PostOrderTraverse(1);

  return 0;

  }

  5. 查找鏈表中倒數第k個結點

  題目:輸入一個單向鏈表,輸出該鏈表中倒數第k個結點。鏈表的倒數第0個結點為鏈表的尾指針。鏈表結點定義如下:

  struct ListNode

  {

  int m_nKey;

  ListNode* m_pNext;

  };

  (最快的方法,只遍歷一遍)

  int FindCoundDownInList(pListNode head,int num)

  {

  pListNode p1,p2;

  p1=p2=head;

  while(num-->0 && p1!=NULL) p1=p1->m_pNext;

  if(p1==NULL) return 0;

  else{

  while(p1!=NULL)

  {

  p1=p1->m_pNext;

  p2=p2->m_pNext;

  }

  return p2->m_nKey;

  }

  }

  6. 求三角形面積

  給出三角形的三個邊長為a、b、c,求三角形的面積。

  (注意考慮是不是三角形)

  double GetArea(int a,int b,int c)

  {

  if(a-b>=c || a+b<=c)

  return -0.1;

  else{

  double s=0.5*(a+b+c);

  double area=sqrt(s*(s-a)*(s-b)*(s-c));

  return area;

  }

  }

  • 相關文章
  • 教師資格考試筆試題和面試題答案及答案教師資格考試筆試題和面試題答案及答案

    一、單項選擇題 1-5ACDAD6-10BCAAB二、多項選擇題 1.ABE2.BDE3.ADE4.AE5.ABCD 6.ACD7.ABE8.ADE9.ABCDE10.ABC三、填空題 1.教育規律 2..

    2024-05-24 16:54:21
  • 教師資格考試筆試題和面試題答案及答案教師資格考試筆試題和面試題答案及答案

    一、單項選擇題 1.學校教育產生于()。 A.奴隸社會初期 B.奴隸社會末期 C.封建社會初期 D.封建社會末期 2.狹義的教育主要是指()。 A.家..

    2024-05-24 16:54:21
  • 農村信用社招聘筆試題和面試題答案及答案農村信用社招聘筆試題和面試題答案及答案

    二、多項選擇題(在下列選項中至少有兩項是符合題意的,請找出恰當的選項,并用2B鉛筆在答題卡相應題號下涂黑所選答案項的信息點,在試卷上作答一律無效,多選或少選均..

    2024-05-27 14:21:40
  • 教師資格考試筆試題和面試題答案及答案教師資格考試筆試題和面試題答案及答案

    一、單項選擇題 1-5ACDAD6-10BCAAB二、多項選擇題 1.ABE2.BDE3.ADE4.AE5.ABCD 6.ACD7.ABE8.ADE9.ABCDE10.ABC三、填空題 1.教育規律 2..

    2024-05-24 16:54:21
  • 教師資格考試筆試題和面試題答案及答案教師資格考試筆試題和面試題答案及答案

    一、單項選擇題 1.學校教育產生于()。 A.奴隸社會初期 B.奴隸社會末期 C.封建社會初期 D.封建社會末期 2.狹義的教育主要是指()。 A.家..

    2024-05-24 16:54:21
  • 農村信用社招聘筆試題和面試題答案及答案農村信用社招聘筆試題和面試題答案及答案

    二、多項選擇題(在下列選項中至少有兩項是符合題意的,請找出恰當的選項,并用2B鉛筆在答題卡相應題號下涂黑所選答案項的信息點,在試卷上作答一律無效,多選或少選均..

    2024-05-27 14:21:40
  • 河北新聞網兩學一做知識競賽(試題+答案完整版)河北新聞網兩學一做知識競賽(試題+答案完整版)

    2016河北新聞網兩學一做知識競賽開賽啦,快來圍觀吧;顒觾热轂橥苿印皟蓪W一做”學習教育深入開展,省委宣傳部、省委組織部組織開展“兩學一做”知識競賽活動,河北?.

    2024-06-04 02:17:24
  • 河北新聞網兩學一做知識競賽活動試題答案河北新聞網兩學一做知識競賽活動試題答案

    2016年河北新聞網兩學一做知識競賽活動試題答案為推動“兩學一做”學習教育深入開展,省委宣傳部、省委組織部組織開展“兩學一做”大型知識競賽。此項活動由河北新聞?.

    2024-06-06 02:19:48
  • 2025年兩學一做學習教育知識競賽活動10篇2025年兩學一做學習教育知識競賽活動10篇

    為隆重紀念中國共產黨建黨95周年,推進我市“兩學一做”學習教育深入開展,推動廣大黨員干部認真學好黨章黨規和*系列重要講話,現將“兩學一做”學習教育知識競賽題予..

    2024-05-31 08:40:33
  • 開展兩學一做學習教育知識競賽活動真題答案開展兩學一做學習教育知識競賽活動真題答案

    144.根據《中國共產黨紀律處分條例》規定,黨的各級代表大會的代表受到(D)處分的,黨組織應當終止其代表資格。A.警告(含)以上B.嚴重警告(含)以上C.撤銷黨內職務(含)以..

    2024-05-27 03:14:20
主站蜘蛛池模板: 克什克腾旗| 白城市| 安溪县| 合川市| 永胜县| 枞阳县| 石家庄市| 郴州市| 金坛市| 肥西县| 呼玛县| 浦江县| 大同市| 隆林| 汕尾市| 台江县| 独山县| 哈尔滨市| 凌源市| 巍山| 鄂托克前旗| 广宗县| 新余市| 万山特区| 遵化市| 福鼎市| 德江县| 循化| 沙坪坝区| 浦江县| 耒阳市| 岑溪市| 贞丰县| 革吉县| 卫辉市| 河间市| 高安市| 聂拉木县| 石城县| 日土县| 伊川县|