亚洲国产日韩欧美在线a乱码,国产精品路线1路线2路线,亚洲视频一区,精品国产自,www狠狠,国产情侣激情在线视频免费看,亚洲成年网站在线观看

軟通動力C語言筆試題

時間:2020-12-12 12:28:31 筆試題目 我要投稿

軟通動力C語言筆試題

  1、局部變量能否和全局變量重名?

軟通動力C語言筆試題

  答:能,局部會屏蔽全局。要用全局變量,需要使用 ":: "

  局部變量可以與全局變量同名,在函數(shù)內(nèi)引用這個變量時,會用到同名的局部變量,而不會用到全局變量。對于有些編譯器而言,在同一個函數(shù)內(nèi)可以定義多個同名的局部變量,比如在兩個循環(huán)體內(nèi)都定義一個同名的局部變量,而那個局部變量的作用域就在那個循環(huán)體內(nèi)。

  2、如何引用一個已經(jīng)定義過的全局變量?

  答:extern

  可以用引用頭文件的方式,也可以用extern關(guān)鍵字,如果用引用頭文件方式來引用某個在頭文件中聲明的全局變理,假定你將那個變寫錯了,那么在編譯期間會報錯,如果你用extern方式引用時,假定你犯了同樣的錯誤,那么在編譯期間不會報錯,而在連接期間報錯。

  3、全局變量可不可以定義在可被多個.C文件包含的頭文件中?為什么?

  答:可以,在不同的C文件中以static形式來聲明同名全局變量。

  可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個C文件中對此變量賦初值,此時連接不會出錯

  4、語句for( ;1 ;)有什么問題?它是什么意思?

  答:和while(1)相同。

  5、do……while和while……do有什么區(qū)別?

  答:前一個循環(huán)一遍再判斷,后一個判斷以后再循環(huán)

  6、請寫出下列代碼的輸出內(nèi)容

  #include

  main()

  {

  int a,b,c,d;

  a=10;

  b=a++;

  c=++a;

  d=10*a++;

  printf( "b,c,d:%d,%d,%d ",b,c,d);

  return 0;

  }

  答:10,12,120

  7、static全局變量與普通的全局變量有什么區(qū)別?static局部變量和普通局部變量有什么區(qū)別?static函數(shù)與普通函數(shù)有什么區(qū)別?

  全局變量(外部變量)的說明之前再冠以static 就構(gòu)成了靜態(tài)的全局變量。全局變量本身就是靜態(tài)存儲方式, 靜態(tài)全局變量當(dāng)然也是靜態(tài)存儲方式。 這兩者在存儲方式上并無不同。這兩者的區(qū)別雖在于非靜態(tài)全局變量的作用域是整個源程序, 當(dāng)一個源程序由多個源文件組成時,非靜態(tài)的全局變量在各個源文件中都是有效的。 而靜態(tài)全局變量則限制了其作用域, 即只在定義該變量的源文件內(nèi)有效, 在同一源程序的其它源文件中不能使用它。由于靜態(tài)全局變量的作用域局限于一個源文件內(nèi),只能為該源文件內(nèi)的函數(shù)公用, 因此可以避免在其它源文件中引起錯誤。

  從以上分析可以看出, 把局部變量改變?yōu)殪o態(tài)變量后是改變了它的存儲方式即改變了它的生存期。把全局變量改變?yōu)殪o態(tài)變量后是改變了它的作用域, 限制了它的使用范圍。

  static函數(shù)與普通函數(shù)作用域不同。僅在本文件。只在當(dāng)前源文件中使用的`函數(shù)應(yīng)該說明為內(nèi)部函數(shù)(static),內(nèi)部函數(shù)應(yīng)該在當(dāng)前源文件中說明和定義。對于可在當(dāng)前源文件以外使用的函數(shù),應(yīng)該在一個頭文件中說明,要使用這些函數(shù)的源文件要包含這個頭文件

  static全局變量與普通的全局變量有什么區(qū)別:static全局變量只初使化一次,防止在其他文件單元中被引用;

  static局部變量和普通局部變量有什么區(qū)別:static局部變量只被初始化一次,下一次依據(jù)上一次結(jié)果值;

  static函數(shù)與普通函數(shù)有什么區(qū)別:static函數(shù)在內(nèi)存中只有一份,普通函數(shù)在每個被調(diào)用中維持一份拷貝

  8、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態(tài)區(qū) )中,動態(tài)申請數(shù)據(jù)存在于( 堆)中。

  9、設(shè)有以下說明和定義:

  typedef union {long i; int k[5]; char c;} DATE;

  struct data { int cat; DATE cow; double dog;} too;

  DATE max;

  則語句 printf( "%d ",sizeof(struct date)+sizeof(max));的執(zhí)行結(jié)果是:___52____

  答:DATE是一個union, 變量公用空間. 里面最大的變量類型是int[5], 占用20個字節(jié). 所以它的大小是20

  data是一個struct, 每個變量分開占用空間. 依次為int4 + DATE20 + double8 = 32.

  所以結(jié)果是 20 + 32 = 52.

  當(dāng)然...在某些16位編輯器下, int可能是2字節(jié),那么結(jié)果是 int2 + DATE10 + double8 = 20

  10、隊列和棧有什么區(qū)別?

  隊列先進(jìn)先出,棧后進(jìn)先出

  11、寫出下列代碼的輸出內(nèi)容

  #include

  int inc(int a)

  {

  return(++a);

  }

  int multi(int*a,int*b,int*c)

  {

  return(*c=*a**b);

  }

  typedef int(FUNC1)(int in);

  typedef int(FUNC2) (int*,int*,int*);

  void show(FUNC2 fun,int arg1, int*arg2)

  {

  INCp= &inc;

  int temp =p(arg1);

  fun( &temp,&arg1, arg2);

  printf( "%d\n ",*arg2);

  }

  main()

  {

  int a;

  show(multi,10, &a);

  return 0;

  }

  答:110

  11、請找出下面代碼中的所以錯誤

  說明:以下代碼是把一個字符串倒序,如“abcd”倒序后變?yōu)?ldquo;dcba”

  1、#include "string.h "

  2、main()

  3、{

  4、 char*src= "hello,world ";

  5、 char* dest=NULL;

  6、 int len=strlen(src);

  7、 dest=(char*)malloc(len);

  8、 char* d=dest;

  9、 char* s=src[len];

  10、 while(len--!=0)

  11、 d++=s--;

  12、 printf( "%s ",dest);

  13、 return 0;

  14、}

  答:

  方法1:

  int main()

  {

  char* src = "hello,world ";

  int len = strlen(src);

  char* dest = (char*)malloc(len+1);//要為\0分配一個空間

  char* d = dest;

  char* s = &src[len-1];//指向最后一個字符

  while( len-- != 0 )

  *d++=*s--;

  *d = 0;//尾部要加\0

  printf( "%s\n ",dest);

  free(dest);// 使用完,應(yīng)當(dāng)釋放空間,以免造成內(nèi)存匯泄露

  return 0;

  }

  方法2:

  #include

  #include

  main()

  {

  char str[]= "hello,world ";

  int len=strlen(str);

  char t;

  for(int i=0; i     {

  t=str[i];

  str[i]=str[len-i-1]; str[len-i-1]=t;

  }

  printf( "%s ",str);

  return 0;

  }

  12。對于一個頻繁使用的短小函數(shù),在C語言中應(yīng)用什么實現(xiàn),在C++中應(yīng)用什么實現(xiàn)?

  答案:c用宏定義,c++用inline

  13。軟件測試都有那些種類?

  答案:黑盒:針對系統(tǒng)功能的測試 白合:測試函數(shù)功能,各函數(shù)接口

  14。確定模塊的功能和模塊的接口是在軟件設(shè)計的那個隊段完成的?

  答案:概要設(shè)計階段

  15。enum string

  {

  x1,

  x2,

  x3=10,

  x4,

  x5,

  }x;

  問x;

  答案:取值在0。1。10。11。12中的一個

  16。unsigned char *p1;

  unsigned long *p2;

  p1=(unsigned char *)0x801000;

  p2=(unsigned long *)0x810000;

  請問p1+5= ;

  p2+5= ;

  答案:801005; 810014。不要忘記了這個是16進(jìn)制的數(shù)字,p2要加20變?yōu)?6進(jìn)制就是14

  選擇題:

  1.Ethternet鏈接到Internet用到以下那個協(xié)議?

  A.HDLC;B.ARP;C.UDP;D.TCP;E.ID

  2.屬于網(wǎng)絡(luò)層協(xié)議的是:

  A.TCP;B.IP;C.ICMP;D.X.25

  3.Windows消息調(diào)度機(jī)制是:

  A.指令隊列;B.指令堆棧;C.消息隊列;D.消息堆棧;

  答案:b,a,c

  二找錯題:

  1.請問下面程序有什么錯誤?

  int a[60][250][1000],i,j,k;

  for(k=0;k<=1000;k++)

  for(j=0;j<250;j++)

  for(i=0;i<60;i++)

  a[i][j][k]=0;

  答案:把循環(huán)語句內(nèi)外換一下

  2。以下是求一個數(shù)的平方的程序,請找出錯誤:

  #define SQUARE(a) ((a)*(a))

  int a=5;

  int b;

  b=SQUARE(a++);

  答案:這個沒有問題,s(a++),就是((a++)×(a++))唯一要注意的就是計算后a=7了

  3。typedef unsigned char BYTE

  int examply_fun(BYTE gt_len; BYTE *gt_code)

  {

  BYTE *gt_buf;

  gt_buf=(BYTE *)MALLOC(Max_GT_Length);

  ......

  if(gt_len>Max_GT_Length)

  {

  return GT_Length_ERROR;

  }

  .......

  }

  答案:要釋放內(nèi)存

  問答題:

  1.IP Phone的原理是什么?

  答案:IPV6

  2.TCP/IP通信建立的過程怎樣,端口有什么作用?

  答案:三次握手,確定是哪個應(yīng)用程序使用該協(xié)議

  1. 用宏定義寫出swap(x,y)

  #define swap(x, y)\

  x $denghao$ x + y;\

  y $denghao$ x - y;\

  x $denghao$ x - y;

  2.數(shù)組a[n],存放了1至n-1個數(shù),其中某個數(shù)重復(fù)一次。寫一個函數(shù),找出被重復(fù)的數(shù)字.時間復(fù)雜度必須為o(n)函數(shù)原型:

  int do_dup(int a[],int n)

  3 一語句實現(xiàn)x是否為2的若干次冪的判斷

  int i $denghao$ 512;

  cout << boolalpha << ((i & (i - 1)) ? false : true) << endl;

  4.unsigned int intvert(unsigned int x,int p,int n)實現(xiàn)對x的進(jìn)行轉(zhuǎn)換,p為起始轉(zhuǎn)化位,n為需要轉(zhuǎn)換的長度,假設(shè)起始點在右邊.如x$denghao$0b0001 0001,p$denghao$4,n$denghao$3轉(zhuǎn)換后x$denghao$0b0110 0001

  unsigned int intvert(unsigned int x,int p,int n){

  unsigned int _t $denghao$ 0;

  unsigned int _a $denghao$ 1;

  for(int i $denghao$ 0; i < n; ++i){

  _t |$denghao$ _a;

  _a $denghao$ _a << 1;

  }

  _t $denghao$ _t << p;

  x ^$denghao$ _t;

  return x;

  }

  一. 選擇題

  1. 在關(guān)系數(shù)據(jù)庫德詢問優(yōu)化中,事先處理文件,如排序、建立索引的目的是:()

  A.優(yōu)化表達(dá)式 B。減少中間結(jié)束 C。擴(kuò)大緩沖數(shù)據(jù) D。 減少掃描文件的時間

  2.進(jìn)程是操作系統(tǒng)中的一個重要概念。進(jìn)程是一個具有一定獨立功能的程序在某個數(shù)據(jù)集合上的一次(A);進(jìn)程是一個(B)的概念,而程序是一個(C)的概念;進(jìn)程的最基本狀態(tài)有(D)。在一個單處理機(jī),若有6個用戶進(jìn)程,在非管態(tài)的某一時刻,處于就緒狀態(tài)的用戶進(jìn)程最多有(E)個。

  供選擇的答案

  A: (1)單獨操作 (2)關(guān)聯(lián)操作 (3) 進(jìn)行活動 (4)并發(fā)活動

  B:(1)靜態(tài) (2)動態(tài) (3)邏輯 (4) 物

  C:(1)物理 (2)邏輯 (3)動態(tài) (4)靜態(tài)

  D:(1)就緒、運行、隱蔽 (2)停止、就緒、運行 (3)運行、就緒、阻塞

  (4)就緒、車消、運行

  E: (1) 5 (2) 6 (3) 1 (4) 4

  3. 有以下幾個條件成立:( )

  (1)如果小王是工人 ,那么小張不是醫(yī)生

  (2)或者小李是工人,或者小王是工人

  (3)如果小張不是醫(yī)生,那么小趙不是學(xué)生

  (4)或者小趙是學(xué)生,或者小周不是經(jīng)理

  以下哪項如果為真,可得出“小李是工人”的結(jié)論?

  (A) 小周不是經(jīng)理

  (B) 小王是工人

  (C) 小趙不是學(xué)生

  (D) 小周是經(jīng)理

  二.簡答題

  1.下面列舉的是常用的排序方法:直接插入排序,二分法插入排序,起泡排序,快速排序,直接選擇排序,堆排序,歸并排序。試問,哪些排序方法是穩(wěn)定的?

  答:(期待您的高見)

  2. 對序列(49,38,65,97,76,27,13,50)采用快速排序法進(jìn)行排序,以序列的第一個元素為基準(zhǔn)元素得到的劃分結(jié)果是什么?

  答:

  3. 請仔細(xì)閱讀下面的SQL,判斷其是否有錯誤,如果有錯誤,請說明錯誤在哪里。

  Select id , name ,age ,count (*)

  From table_name

  Where name like “ %s%”

  Group by name

  4. 請用面向?qū)ο蠓治龅姆椒,分?ldquo;我用電腦寫程序”這句話的對象、屬性和方法。

  三 問答題

  電影《達(dá)芬奇密碼》中講到了一個非常有意思的數(shù)字序列---菲波拉契序列。請用任意計算機(jī)語言實現(xiàn)一段小程序,該程序在屏幕上輸出1到1000之間的非波拉契序列。

  非波拉契序列:1,1,2,3,5,8,13,21,34,……

  要求:用程序描述 核心算法。語言不限。

  1. C++中如何阻止一個類被實例化?

  2. 一般在什么時候構(gòu)造函數(shù)被聲明成private呢?

  3. 什么時候編譯器會生成默認(rèn)的copy constructor呢?

  4. 如果你已經(jīng)寫了一個構(gòu)造函數(shù),編譯器還會生成copy constructor嗎?

  5. struct和class有什么區(qū)別?

  答:默認(rèn)的訪問級別不同,struct是public,class是private

  6. 沒有別的不同了嗎?

  7. 為什么說如果一個類作為基類,則它的析構(gòu)函數(shù)要聲明成virtual的?

  8. inline的函數(shù)和#define有什么區(qū)別?

  9. inline是什么意思?

  10. 那你說說什么時候會真的被inline,什么時候不會呢?

  11. 如果把一個類的成員函數(shù)寫在類的聲明中是什么意思?

  12. public繼承和private繼承有什么架構(gòu)上的區(qū)別?

  13. 在多繼承的時候,如果一個類繼承同時繼承自class A和class B,而class A和

  B中都有一個函數(shù)叫foo(),如何明確的在子類中指出override哪個父類的foo()?

  14. 虛擬繼承的語法是什么?

  15. 部分模版特例化

  1.什么是平衡二叉樹?編寫一個刪除平衡二叉樹的程序?

  2.寫一個程序,求有向有權(quán)圖兩點之間的最小權(quán)?

  3.根據(jù)你的理解,寫出Cstring類的構(gòu)造函數(shù)和析構(gòu)函數(shù)?

  4.使用C語言實現(xiàn)對ini文件的訪問,使程序可以對int,double,字符串類進(jìn)行讀寫。

  5.n×n個方格(n為任意整數(shù)),定義若兩個格有公共邊則稱兩個格相鄰,F(xiàn)將 個格中的N個格子圖黑,使每個格子都與黑格子相鄰。試編程,使N最小。

  1

  #define pi 3.14

  #define Area(R) pi*R*R

  main()

  {

  int r1=5,r2=2;

  double s=0;

  s=Area(r1-r2);

  printf("The area is %f",s);

  }

  求結(jié)果

  2

  函數(shù) int compare(int a,int b),定義為該函數(shù)的函數(shù)指針P:為_______________

  3

  #include

  void sub(char*s,int num)

  {

  int i ,j=num;

  char t;

  while(j-->1)

  {

  for(i=0;i{

  if(s[i]{

  t=s[i];

  s[i]=s[i+1];

  s[i+1]=t;

  }

  }

  }

  }

  main()

  {

  char*s="CEAeded";

  sub(s,6);

  printf("%s\n",s)

  }

  求結(jié)果

  4

  交換兩個變量的值,不使用第三個變量,即a=3,b=5交換

  后b=3,a=5

  unsigned char a=3,b=5;

  5

  #define N 100

  void GetMemory1(char*p)

  {

  p=(char*)malloc(sizeof(char)*N);

  strcpy(p,"Have a good day!");

  }

  char*GetMemory2(void)

  {

  char p[]="Have a good day!";

  return p;

  }

  void main(void)

  {

  char*str1=NULL,*str2=NULL;

  GetMemory1(str1);

  GetMemory2(str2);

  printf("\nstr1:%s",str1);

  printf("\nstr2:%s",str2);

  6

  構(gòu)造N個結(jié)點的單鏈表返回鏈表頭指針,要求鏈表中各結(jié)點順序

  與結(jié)點數(shù)據(jù)輸入順序相反,例如輸入1,2,3,4,5,形成的鏈表為

  head->5 4 3 2 1 ,補(bǔ)充程序

  #define N 10

  typedef struct Node

  {

  int data;

  struct Node*next;

  }NODE;

  int Get_Data(int i);定義省略

  Node*Create_u()

  {

  int i;

  NODE*p,*Head=NULL;

  for(i=0;i{

  VP=New NODE;

  P->Data=Get_Data(i);

  ________________;

  ________________;

  }

  return Head;

  }

  7

  N個結(jié)點鏈表,每個結(jié)點中存放一個字符,判斷鏈表存放的字符是否

  中心對稱,即a b c c b a或a b c b a,補(bǔ)充程序

  typedef struct Node

  {

  int data;

  struct Node*next;

  }NODE;

  bool Is_symmeic(NODE*head,*int n)

  {

  char D[N];

  int i,d;

  __________;

  for(i=0;i{

  D[i]=head->data;

  head=head->next;

  }

  if(__________)

  {

  head=head->next;

  }

  while(head)

  {

  _______________;

  if(D[i]!=head->data)

  {

  return false;

  }

  head=head->next;

  }

  return true;

  }

  8

  str中只含有大寫和小寫字母函數(shù)change_move(char*str)將字符串中大寫改成*并

  移到前面小寫后返回*的個數(shù)

  如AabBdcYY改為*****abd,返回5

  int chang_move(char*str)

  {

  int len,i,curstr=-1;

  len=strlen(str);

  for(i=len-1;i>=0;i--)

  {

  if(str[i]>='A'&&str[i]<='Z')

  {

  str[i]='*';

  if(cursor==-1)

  {

  cursor=i;

  }

  else if(cursor>i)

  {

  _____________;

  str[i]='*';

  _____________;

  }

  }

  return____________;

  }

  9

  求兩個字符串的第一個公共子串,并返回該子串

  如:"a b c d e f g e h i" "a a c d e f * * g e h i"

  第一個為"c d e f";不許用strcmp()

  char*Maxf(char*str1,char*str2)

  {

  }

【軟通動力C語言筆試題】相關(guān)文章:

C語言基礎(chǔ)筆試題12-27

C語言筆試題集錦12-27

外企C語言筆試題12-25

C語言筆試題回憶12-25

C語言筆試題總結(jié)12-25

東軟C/C++筆試題及參考答案11-14

c語言常見筆試題總結(jié)12-25

C語言常用筆試題12-24

華為C語言招聘筆試題目07-26

上海貝爾c語言筆試題07-03