c语言面试编程题

c语言面试编程题

  1、读文件 file1.txt 的'内容(例如):

  12

  34

  56

  输出到 file2.txt:

  56

  34

  12

  #include

  #include

  int main(void)

  {

  int MAX = 10;

  int *a = (int *)malloc(MAX * sizeof(int));

  int *b;

  FILE *fp1;

  FILE *fp2;

  fp1 = fopen("a.txt","r");

  if(fp1 == NULL)

  {printf("error1");

  exit(-1);

  }

  fp2 = fopen("b.txt","w");

  if(fp2 == NULL)

  {printf("error2");

  exit(-1);

  }

  int i = 0;

  int j = 0;

  while(fscanf(fp1,"%d",&a[i]) != EOF)

  {

  i++;

  j++;

  if(i >= MAX)

  {

  MAX = 2 * MAX;

  b = (int*)realloc(a,MAX * sizeof(int));

  if(b == NULL)

  {

  printf("error3");

  exit(-1);

  }

  a = b;

  }

  }

  for(;--j >= 0;)

  fprintf(fp2,"%d\n",a[j]);

  fclose(fp1);

  fclose(fp2);

  return 0;

  }

  2、写一段程序,找出数组中第 k 大小的数,输出数所在的位置,

c语言面试编程题

。例如{2,4,3,4,7}中,第一大的数是 7,位置在 4。第二大、第三大的数都是 4,位置在 1、3 随便输出哪一个均可。

  函数接口为:int find_orderk(const int* narry,const int n,const int k)

  要求算法复杂度不能是 O(n^2)

  可以先用快速排序进行排序,其中用另外一个进行地址查找代码如下,在 VC++6.0 运行通过。

  //快速排序

  #include

  usingnamespacestd;

  intPartition (int*L,intlow,int high)

  {

  i

nttemp = L[low];

  intpt = L[low];

  while (low < high)

  {

  while (low < high && L[high] >= pt)

  --high;

  L[low] = L[high];

  while (low < high && L[low] <= pt)

  ++low;

  L[low] = temp;

  }

  L[low] = temp;

  returnlow;

  }

  voidQSort (int*L,intlow,int high)

  {

  if (low < high)

  {

  intpl = Partition (L,low,high);

  QSort (L,low,pl - 1);

  QSort (L,pl + 1,high);

  }

  }

  intmain ()

  {

  intnarry[100],addr[100];

  intsum = 1,t;

  cout << "Input number:" << endl;

  cin >> t;

  while (t != -1)

  {

  narry[sum] = t;

  addr[sum - 1] = t;

  sum++;

  cin >> t;

  }

  sum -= 1;

  QSort (narry,1,sum);

  for (int i = 1; i <= sum;i++)

  cout << narry[i] << '\t';

  cout << endl;

  intk;

  cout << "Please input place you want:" << endl;

  cin >> k;

  intaa = 1;

  intkk = 0;

  for (;;)

  {

  if (aa == k)

  break;

  if (narry[kk] != narry[kk + 1])

  {

  aa += 1;

  kk++;

  }

  }

  cout << "The NO." << k << "number is:" << narry[sum - kk] << endl;

  cout << "And it's place is:" ;

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

  {

  if (addr[i] == narry[sum - kk])

  cout << i << '\t';

  }

  return0;

  }

相关文章

²©Ê¿Ñ§Î»Ñо¿Éúר¼ÒÐÅ

±»ÍƼö¿¼ÉúÐÕÃû &...
资料大全2017-06-02
²©Ê¿Ñ§Î»Ñо¿Éúר¼ÒÐÅ

抗战胜利70周年纪念币

■“央行”绝密铸币工艺标准! ■人民币制作团队的专业研发标准,人民币设计大师——李斌操刀创作! ■带“元”面额货币,可流通、能保值、更升值! ■镜面999纯黄金铸造,国家单位权威检测! ■枚枚都是沉甸...
资料大全2018-09-02
抗战胜利70周年纪念币

职工的休息时间有什么规定?

一.劳动者的休息休假权1、工作间隙休息。是指劳动者在工作日的工作时间内享有的休息时间和用膳时间。《劳动法》对此虽未作规定,但作为劳动者一种休息的习惯已实行多年。例如许多用人单位在上、下午工作期间允许劳...
资料大全2014-05-07
职工的休息时间有什么规定?

全年一次性奖金个人所得税计算方法

1、全年一次性奖金,单独作为一个月工资、薪金所得计算纳税2、将当月取得的全年一次性奖金,除以12个月,以其商数确定适用税率和速算扣除数。(详见下表)全年一次性奖金计算明细表序 全年一次性奖金 年平均后...
资料大全2019-02-05
全年一次性奖金个人所得税计算方法

猫的歇后语

关于猫的歇后语1猫儿念经——假充善人猫嘴里的老鼠——剩不下啥猫咬老虎——冷不防猫爪伸到鱼缸里——想捞一把猫披老虎——抖威风猫肚子放虎胆——凶不起来猫头鹰抓耗子——干好事,落骂名猫头鹰唱歌——瞎叫唤猫守...
资料大全2013-08-09
猫的歇后语

乡村振兴工作方案

做好可行性分析是做好工作方案的前提。在计划开展某项工作时,我们就要有针对性的做几份工作方案,现在你是否对工作方案一筹莫展呢?以下是小编帮大家整理的乡村振兴工作方案,希望能够帮助到大家。  乡村振兴工作...
资料大全2012-08-03
乡村振兴工作方案