sinat_31829943 2015-10-17 12:52 采纳率: 60%
浏览 5437
已采纳

C语言 给定一个整数序列和一个数k,求这个序列中第k小的数。

C语言 给定一个整数序列和一个数k,求这个序列中第k小的数。

我的程序

 #include<stdio.h>
int n[10000];
void Nok()
{
  int i=0,j=0,t,k,q=0;
  char c;
  scanf("%d",&n[i++]);
  c=getchar();
  while(c!='\n')
  {
      scanf("%d",&n[i++]);
      c=getchar();
  }
  t=i-2;
  k=n[i-1];//最后一个数是k
  while(k!=0)
  {   
   for(i=0;i<=t;i++)//寻找k次最小值,每次将最小值所对应变量赋值其下一变量消掉此次最小值(最后一次不变直接输出)
   {
     if(n[i]<n[q])
     {          
        q=i;
     }
   }
   k--;
   if(k==0) printf("%d\n",n[q]);
   else {n[q]=n[q+1]; q++;}
  }  
}
void main()
{
   Nok();
}

结果很奇怪不知道程序哪里有问题麻烦帮忙看一看

  • 写回答

4条回答 默认 最新

  • 纵横车 2015-10-17 13:11
    关注

    n[q]=n[q+1];这句如果q是最后一个数,呢q+1不就越界了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog