鱼C论坛

 找回密码
 立即注册
查看: 2016|回复: 2

[已解决]最小差值程序哪里有问题

[复制链接]
发表于 2022-10-22 22:00:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
int main()
{
        int n,i,j,k,min=10000;
        int a[n];
        scanf("%d",&n);

        for(i=0;i<n;i++)
        {
                scanf("%d",&a[i]);
        }
        for(j=1;j<n;j++)
        
        for(k=0;k<j;k++) 
                {
                        if(a[k]==a[j])
                        {
                        min=0;
                        }
                        else if(a[k]-a[j]>0)
                        {
                                if(a[k]-a[j]<min)
                                {
                                        min=a[k]-a[j];
                                }
                        }
                        else if(a[j]-a[k]>0)
                        {
                                if(a[j]-a[k]<min)
                                min=a[j]-a[k];
                        }
                }
        printf("%d",min);
        return 0;
}


最佳答案
2022-10-22 22:17:37
本帖最后由 jackz007 于 2022-10-22 22:35 编辑

        这两句原来的顺序是错的,必须改过来,不然,在我这里用 gcc 编译后,运行时直接崩溃。
        scanf("%d" , & n)     ;
        int a[n]              ;
        运行结果似乎是对的
D:\[00.Exerciese.2022]\C>x
5
1 4 8 3 12
1
D:\[00.Exerciese.2022]\C>
        我写的代码,谨供楼主参考
#include<stdio.h>
int main()
{
        int i , j , k , n , min                                       ;
        scanf("%d" , & n)                                             ;
        int a[n]                                                      ;
        for(i = 0 ; i < n ; i ++) scanf("%d" , & a[i])                ;
        min = (a[0] > a[1]) ? a[0] - a[1] : a[1] - a[0]               ;
        for(i = 0 ; i < n - 1 ; i ++) {
                for(j = i + 1 ; j < n ; j ++) {
                        k = (a[j] > a[i]) ? a[j] - a[i] : a[i] - a[j] ;
                        if(k < min) min = k                           ;
                }
        }
        printf("%d\n" , min)                                          ;
        return 0                                                      ;
}
        

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-10-22 22:02:09 | 显示全部楼层
本帖最后由 原来是我错付了 于 2022-10-22 22:16 编辑

我自己发现错误了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-22 22:17:37 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2022-10-22 22:35 编辑

        这两句原来的顺序是错的,必须改过来,不然,在我这里用 gcc 编译后,运行时直接崩溃。
        scanf("%d" , & n)     ;
        int a[n]              ;
        运行结果似乎是对的
D:\[00.Exerciese.2022]\C>x
5
1 4 8 3 12
1
D:\[00.Exerciese.2022]\C>
        我写的代码,谨供楼主参考
#include<stdio.h>
int main()
{
        int i , j , k , n , min                                       ;
        scanf("%d" , & n)                                             ;
        int a[n]                                                      ;
        for(i = 0 ; i < n ; i ++) scanf("%d" , & a[i])                ;
        min = (a[0] > a[1]) ? a[0] - a[1] : a[1] - a[0]               ;
        for(i = 0 ; i < n - 1 ; i ++) {
                for(j = i + 1 ; j < n ; j ++) {
                        k = (a[j] > a[i]) ? a[j] - a[i] : a[i] - a[j] ;
                        if(k < min) min = k                           ;
                }
        }
        printf("%d\n" , min)                                          ;
        return 0                                                      ;
}
        

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-17 05:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表