c语言面试编程题

更新时间:2023-02-16 21:05:31 发布时间:24小时内 作者:文/会员上传 下载docx 收藏

  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 大小的数,输出数所在的位置。例如{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)

  {

  inttemp = 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;

  }

推荐阅读:

  应聘意见怎么写

  面试题4

  会计应聘信的写法

  面试离职原因

  最新记者面试题目

  银行应聘信范文

热门标签: 语言 面试试题
c语言面试编程题.docx

将本文的Word文档下载到电脑

推荐度:

下载

为您推荐

【物流管理毕业论文】物流管理毕业实习报告范文3000字

  物流管理毕业实习报告范文有哪些呢?以下是由本站小编为大家精心整理的“物流管理毕业实习报告范文3000字”,仅供参考,欢迎大家阅读,希望能够帮助到大家哦。  物流管理毕业实习报告范文3000字  一、实习目的  初步认识社会,进一步了解营销管理与物流运输组织的相关知识,从社会实践中,逐步完善自我、发展自我,最终完全融入现实生活当中,做一名言出必行、知识与能力兼备、符合社会主义发展目标的合格大学生

管理实习报告2023-03-07

[新课标人教版语文]新课标人教版一年级数学下册教学计划

制定教学计划要根据本班学生的特点和实际情况,创造性地使用教材,设计教学过程。下面是由i乐德范文网小编带来的“新课标人教版一年级数学下册教学计划”,欢迎阅读。

教学工作计划2023-06-26

大学生认识实习报告|大学生社会实习报告(超市收银员)

  身处实际的工作环境和社会环境,在实践中重新认识社会、认识自己,明白社会上都有什么样的人,社会需要什么样的人,自己要做什么样的人,这些都是学生在实习中能学到的东西。下面是由本站小编带来的范文“大学生社会实习报告(超市收银员)”,欢迎阅读。  大学生社会实习报告(超市收银员)  这个寒假是我进入大学的第一个寒假,也是我人生20年来最有意义的一个寒假。今年寒假里,我进行了社会实践,真正接触这个社会,

大学生实习报告2023-03-07

怎样写辞职信_写辞职信的注意事项

  辞职在现在的社会是屡见不鲜的事情,但也有地方需要注意。小编精心整理了《写辞职信的注意事项》,欢迎阅读,仅供参考,如果想了解更多的相关信息,请继续关注我们本站。  注意事项一:辞职信的写法有讲究  首先,写辞职信并不是写辞职申请,申请是要双方达成一致才有效的,也就是说企业批准了你的申请,你才可以辞职,而劳动法赋予的辞职权是绝对的,辞职信其实是一种通知,告诉企业你将在三十天后解除劳动合同,离开企业

辞职报告2023-03-07

辞职信怎么写 范文|美容师辞职信范文

  小编特别推荐  辞职信模板 | 辞职信格式 | 辞职信怎么写 | 英文辞职信  对于美容师来说,辞职是件很麻烦的事情,因为要写明辞职原因。小编精心整理了《美容师辞职信范文》,欢迎阅读,仅供参考,如果想了解更多的相关信息,请继续关注我们本站。美容师辞职信范文【一】尊敬的经理:  我带着复杂的心情写这封辞职信。因为您对我的能力的信任,使我得以加入xx美容院,并且在短短的几周时间获得了很多的机遇和挑

辞职报告2023-03-07

【辞职申请书范文】怀孕辞职申请书

  小编特别推荐  辞职信模板 | 辞职信格式 | 辞职信怎么写 | 英文辞职信  母亲的伟大,在于生命的孕育,因为怀孕而辞职的妈妈,也就可以理解了。小编精心整理了《怀孕辞职申请书》,欢迎阅读,仅供参考,如果想了解更多的相关信息,请继续关注我们本站。怀孕辞职申请书【一】尊敬的领导:  您好!  我怀着复杂的心情写这封辞职信。  首先,在公司工作的这几个月以来,我收获良多,在领导以及同事的帮助下使我

辞职报告2023-03-07