| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2202 人关注过本帖
标题:麻烦能够各位指点一下错误,调试一上午,无奈ing
只看楼主 加入收藏
miyaya
Rank: 2
等 级:论坛游民
帖 子:15
专家分:35
注 册:2017-11-10
收藏
得分:0 
回复 楼主 miyaya
我改完之后程序可以出结果了,但是那些数字都是负数不知道有问题,麻烦大家能告诉一下吗?
#include<stdio.h>
#define N 10
int fun(int a[N])
{
    int m,n,i;
    for(m=0;m<N-1;m++)
        for(n=0;n<N-1-m;m++)
        {
            if(a[n]>a[n+1])
            {
                i=a[n];
                a[n]=a[n+1];
                a[n+1]=i;
            }
        }
        return a[N];
}
void main()
{
    int t,k,l,m,a[N];
    printf("请输入9个数字:\n");
    for(t=0;t<9;t++)
    scanf("%d",&a[t]);
    fun(a);
    printf("please imput a nuber;\n");
    scanf("%d",&k);
    for(t=0;t<N;t++)
    {
        if(k>a[t])
        {
            for(m=t+1;m<N;m++)
            {
                l=a[m];
                a[m]=k;
                k=l;
            }
        }
        a[t+1]=k;
        continue;
    }
    for(t=0;t<N;t++)
        printf("%d",a[t]);
}
2017-12-01 16:09
虫眼
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:10
帖 子:314
专家分:1121
注 册:2017-11-29
收藏
得分:0 
出现负值是因为数组你没有初始化
int main(void)
{
    int t,k;
    int a[N]={0};
2017-12-01 16:15
虫眼
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:10
帖 子:314
专家分:1121
注 册:2017-11-29
收藏
得分:0 
按你的思路改了一下程序,水平有限请见谅。
程序代码:
#include<stdio.h>
#define N 10
void fun(int a[])
{
      int i,j,k;
      for(j=0;j<N-2;j++)
      {
           for(i=0;i<N-2-j;i++)
           {
                if(a[i]>a[i+1])
                {
                     k=a[i];
                     a[i]=a[i+1];
                     a[i+1]=k;
                }
           }
      }
}

void ist(int a[],int s)
{
int b=N;   

    for( ;s<b;b--)
    {
        a[b-1]=a[b-2];
    }
    a[s-1]=s;
       

}
int main(void)
{
    int t,k;
    int a[N]={0};
    printf("请输入%d个数字:\n",N-1);
    for(t=0;t<N-1;t++)
    scanf("%d",&a[t]);
    fun(a);
    printf("请输入1个数字;\n");
    scanf("%d",&k);
    ist(a,k);
    puts("\n");
    for(t=0;t<N;t++)
    {
        printf("%d\n",a[t]);   

    }
       

return(0);
}

2017-12-01 17:11
miyaya
Rank: 2
等 级:论坛游民
帖 子:15
专家分:35
注 册:2017-11-10
收藏
得分:0 
回复 13楼 虫眼
不会不会,你愿意帮助我我已经很感谢了
2017-12-01 20:26
炎天
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:桃花岛
等 级:贵宾
威 望:29
帖 子:1218
专家分:4986
注 册:2016-9-15
收藏
得分:5 
此帖针对11楼的问题

int fun(int a[N])
{
    int m, n, i;
    for (m = 0; m<N - 1; m++)
        for (n = 0; n<N - 1 - m-1; n++)   // 在减去一个1,越界,
        {
            if (a[n]>a[n + 1])
            {
                i = a[n];
                a[n] = a[n + 1];
                a[n + 1] = i;
            }
        }
    return a[N];
}


for (t = 0; t<N-1; t++)      //到这一步,只确定了前九个数
    {
        if (k<a[t])       //当然你可以用大于号(不过得修改好多), 故此用小于号找到原数组中的第一个比将插入数大的数
        {
            for (m = t ; m<N-1; m++)
            {
                l = a[m];
                a[m] = k;
                k = l;
              
            }
            
        }
        a[N-1] = k;   
        continue;
        
    }

[此贴子已经被作者于2017-12-1 21:26编辑过]


早知做人那么辛苦!  当初不应该下凡
2017-12-01 21:18
墨点
Rank: 2
等 级:论坛游民
帖 子:3
专家分:16
注 册:2017-12-1
收藏
得分:5 
我就不定义函数了:
#include<stdio.h>
void main()
{
    int i,j,k,temp;
    int a[10]={0};
    for(i=0;i<9;i++)
    scanf("%d",&a[i]);
    for(i=0;i<9;i++)
    {
        k=i;
        for(j=i+1;j<9;j++)//选择法排序
         if(a[j]<a[k])k=j;
        if(k!=i)
        {
            temp=a[i];
            a[i]=a[k];
            a[k]=temp;
        }
    }
    for(i=0;i<10;i++)
    printf("%2d",a[i]);
    printf("\n插入数:");
    scanf("%d",&a[9]);
    for(i=9;i>=0;i--)//从后向前交换顺序
    if(a[i]<a[i-1])
    {
        temp=a[i-1];
        a[i-1]=a[i];
        a[i]=temp;
    }
    for(i=0;i<10;i++)
    printf("%2d",a[i]);
}
2017-12-01 21:47
miyaya
Rank: 2
等 级:论坛游民
帖 子:15
专家分:35
注 册:2017-11-10
收藏
得分:0 
回复 15楼 炎天
谢谢!
2017-12-03 09:39
miyaya
Rank: 2
等 级:论坛游民
帖 子:15
专家分:35
注 册:2017-11-10
收藏
得分:0 
回复 16楼 墨点
谢谢
2017-12-03 09:40
快速回复:麻烦能够各位指点一下错误,调试一上午,无奈ing
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.042694 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved