鱼C论坛

 找回密码
 立即注册
查看: 2427|回复: 7

[已解决]清大佬帮我看看哪里错了

[复制链接]
发表于 2022-9-29 21:27:54 | 显示全部楼层 |阅读模式

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

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

x
题目是这样的:输入十个整型数,从小到大排序取中间八个求均值
我的代码
#include<stdio.h>

int main()
{
        int a[10];
        int n, j, num, flag = 0;
                for (n = 0;n <= 9;n++)
                {
        printf("Please enter ten number which you want to calculate:(n-n)");
        scanf("%d", &a[n]);
        if(a[n] < a[n-1])
        {
                a[n] = j;
                a[n - 1] = a[n];
                a[n - 1] = j;
        }
                }
                for(flag = 1;flag <= 8;flag++)
                {
                num = num + a[flag];
                }
                printf("The result is:%d\n", num/8);

                return 0;
}
最佳答案
2022-9-29 22:01:39
本帖最后由 jackz007 于 2022-9-29 22:08 编辑
#include<stdio.h>

int main(void)
{
        int a[10] , n , j , num , flag = 0                                          ;
        for(n = 0 ; n <= 9 ; n ++) {
                printf("Please enter ten number which you want to calculate:(n-n)") ;
                scanf("%d", &a[n])                                                  ;
                if(a[n] < a[n-1]) {                                                    // 这个排序不彻底
                        a[n] = j                                                    ;  // j = ?这一句不是在砸场子吗
                        a[n - 1] = a[n]                                             ;
                        a[n - 1] = j                                                ;
                }
        }
        for(flag = 1 ; flag <= 8 ; flag ++) num = num + a[flag]                     ;  // num 没有初始化为 0
        printf("The result is:%d\n" , num / 8)                                      ;
        return 0                                                                    ;
}
        请参考我修改的代码:
#include<stdio.h>

int main(void)
{
        int a[10] , i , j , n , num , t                                                 ;
        for(n = 10 , i = 0 ; i < n ; i ++) {
                printf("Please enter ten number which you want to calculate : (n-n) ")  ;
                scanf("%d", & a[i])                                                     ;
                for(j = i ; j && a[j] < a[j - 1] ; j --) {
                        t = a[j - 1]                                                    ;
                        a[j - 1] = a[j]                                                 ;
                        a[j] = t                                                        ;
                }
        }
        for(num = 0 , i = 1 ; i < n - 1 ; i ++) num += a[i]                             ;
        printf("The result is : %.2f\n" , 1.0 * num / 8.0)                              ;
}
        编译、运行实况:
D:\[00.Exerciese.2022]\C>g++ -o x x.c

D:\[00.Exerciese.2022]\C>x
Please enter ten number which you want to calculate : (n-n) 7
Please enter ten number which you want to calculate : (n-n) 4
Please enter ten number which you want to calculate : (n-n) 8
Please enter ten number which you want to calculate : (n-n) 2
Please enter ten number which you want to calculate : (n-n) 5
Please enter ten number which you want to calculate : (n-n) 9
Please enter ten number which you want to calculate : (n-n) 10
Please enter ten number which you want to calculate : (n-n) 5
Please enter ten number which you want to calculate : (n-n) 7
Please enter ten number which you want to calculate : (n-n) 3
The result is : 6.00

D:\[00.Exerciese.2022]\C>

这样子出错了

这样子出错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-29 21:45:32 | 显示全部楼层
#include <stdio.h>

int main() {
    int a[10];
    //int n, j, num, flag = 0;
    int n, num, flag = 0;
    for(n = 0; n <= 9; n++) {
        printf("Please enter ten number which you want to calculate:(n-n): ");
        scanf("%d", &a[n]);
        /*
        if(a[n] < a[n - 1]) {
            a[n] = j;
            a[n - 1] = a[n];
            a[n - 1] = j;
        }
        */
    }
    for(size_t i = 0; i < 10; ++i) {
        for(size_t j = i + 1; j < 10; ++j) {
            if(a[i] > a[j]) {
                int temp = a[i];
                a[i] = a[j];
                a[j] = temp;
            }
        }
    }
    num = 0;        // ************
    for(flag = 1; flag <= 8; flag++) {
        num = num + a[flag];
    }
    printf("The result is: %d\n", num / 8);
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-29 22:01:39 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2022-9-29 22:08 编辑
#include<stdio.h>

int main(void)
{
        int a[10] , n , j , num , flag = 0                                          ;
        for(n = 0 ; n <= 9 ; n ++) {
                printf("Please enter ten number which you want to calculate:(n-n)") ;
                scanf("%d", &a[n])                                                  ;
                if(a[n] < a[n-1]) {                                                    // 这个排序不彻底
                        a[n] = j                                                    ;  // j = ?这一句不是在砸场子吗
                        a[n - 1] = a[n]                                             ;
                        a[n - 1] = j                                                ;
                }
        }
        for(flag = 1 ; flag <= 8 ; flag ++) num = num + a[flag]                     ;  // num 没有初始化为 0
        printf("The result is:%d\n" , num / 8)                                      ;
        return 0                                                                    ;
}
        请参考我修改的代码:
#include<stdio.h>

int main(void)
{
        int a[10] , i , j , n , num , t                                                 ;
        for(n = 10 , i = 0 ; i < n ; i ++) {
                printf("Please enter ten number which you want to calculate : (n-n) ")  ;
                scanf("%d", & a[i])                                                     ;
                for(j = i ; j && a[j] < a[j - 1] ; j --) {
                        t = a[j - 1]                                                    ;
                        a[j - 1] = a[j]                                                 ;
                        a[j] = t                                                        ;
                }
        }
        for(num = 0 , i = 1 ; i < n - 1 ; i ++) num += a[i]                             ;
        printf("The result is : %.2f\n" , 1.0 * num / 8.0)                              ;
}
        编译、运行实况:
D:\[00.Exerciese.2022]\C>g++ -o x x.c

D:\[00.Exerciese.2022]\C>x
Please enter ten number which you want to calculate : (n-n) 7
Please enter ten number which you want to calculate : (n-n) 4
Please enter ten number which you want to calculate : (n-n) 8
Please enter ten number which you want to calculate : (n-n) 2
Please enter ten number which you want to calculate : (n-n) 5
Please enter ten number which you want to calculate : (n-n) 9
Please enter ten number which you want to calculate : (n-n) 10
Please enter ten number which you want to calculate : (n-n) 5
Please enter ten number which you want to calculate : (n-n) 7
Please enter ten number which you want to calculate : (n-n) 3
The result is : 6.00

D:\[00.Exerciese.2022]\C>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-29 22:37:46 | 显示全部楼层
本帖最后由 桃花飞舞 于 2022-9-29 22:41 编辑
#include <stdio.h>

void bubble_sort(int *a,int n);

int main()
{
        int a[10] = {0};
        int n,num = 0, flag = 0;
        for (n = 0;n <= 9; n++)
        {
            printf("Please enter ten number which you want to calculate:(10-%d)",n);
            scanf("%d", &a[n]);
            // if(a[n] < a[n-1])
            // {
            //         a[n] = j;
            //         a[n - 1] = a[n];
            //         a[n - 1] = j;
            // }
        }

        bubble_sort(a,10);
        
        for(flag = 1;flag <= 8;flag++)
        {
            num = num + a[flag];
        }

        printf("The result is:%d\n", num/8);

  return 0;
}

void bubble_sort(int *a,int n)
{
    int i,j,k,tmp = 0;
    //遍历的次数n-1
    for(i=1; i < n; i++)
    {   //比较次数
        for(j=1,k=0;j < n-i; j++,k++)
        {
            //前后比较
            if(a[k] > a[k+1])
            {
                tmp = a[k];
                a[k] = a[k+1];
                a[k+1] = tmp;
            }
        }
    }
}
第一 :你的结果是由于  int num;这里一开始没有给num 初始值,num里面是随机值,造成的。可以改为int num = 0;
第二:排序也有错误,楼上都有说
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-29 22:48:25 | 显示全部楼层
桃花飞舞 发表于 2022-9-29 22:37
第一 :你的结果是由于  int num;这里一开始没有给num 初始值,num里面是随机值,造成的。可以改为int num ...

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

使用道具 举报

 楼主| 发表于 2022-9-29 22:49:32 | 显示全部楼层

你好,学生,膜拜,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-29 22:52:45 | 显示全部楼层
jackz007 发表于 2022-9-29 22:01
请参考我修改的代码:

        编译、运行实况:

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

使用道具 举报

发表于 2022-9-30 15:42:45 | 显示全部楼层
本帖最后由 jhq999 于 2022-9-30 15:55 编辑

单链表插入排序
#include <stdio.h>

int main(void)
{
    int num[11][2]={0},i=0,j=0,sum=0;
    num[0][1]=-1;
    for(i=1;i<=10;i+=1)
    {
        scanf("%d",*(num+i));
        for(j=0;num[j][1]>=0&&num[i][0]>num[num[j][1]][0];j=num[j][1]);
        num[i][1]=num[j][1];
        num[j][1]=i;
    }
    sum=0;
    for(i=num[0][1];num[num[i][1]][1]>=0;i=num[i][1])
    {
        printf("%4d",num[num[i][1]][0]);
        sum+=num[num[i][1]][0];
    }
    printf("\n%d %.2f",sum,(float)sum/8);
    return 0;
}
如果不用排序的话
#include <stdio.h>

int main(void)
{
    int num[12]={0},i=0,j=0,sum=0;
    scanf("%d",num);
    sum=num[11]=num[10]=num[0];
    for(i=1;i<10;i+=1)
    {
        scanf("%d",num+i);
        if(num[10]>num[i])
            num[10]=num[i];
        else if(num[11]<num[i])
            num[11]=num[i];
        sum+=num[i];
    }

    printf("\n%d %.2f",sum-num[10]-num[11],(float)(sum-num[10]-num[11])/8);
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-27 13:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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