鱼C论坛

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

[已解决]还是没有输出

[复制链接]
发表于 2023-11-18 14:57:58 | 显示全部楼层 |阅读模式
本帖为密码帖 ,请输入密码 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-18 14:58:13 | 显示全部楼层    本楼为最佳答案   
问题在于内部循环的条件判断有误,导致排序部分无法正确执行。以下是修改后的代码:
#include <stdio.h>

int main()
{
    int n, i, j, temp;
    int a[11];
    int sum[1100];
    while (scanf("%d", &n) != EOF && n != 0)
    {
        for (i = 0; i < n; i++)
        {
            scanf("%d", &a[ i]);
        }
        for (i = 0; i < n; i++)
        {
            int num = 0;
            int k = a[ i];
            while (k != 0)
            {
                int digit = k % 10;
                k = k / 10;
                num += digit;
            }
            sum[ i] = num;
        }
        for (i = 0; i < n - 1; i++)
        {
            for (j = 0; j < n - i - 1; j++)  // 此处修改为正确的条件判断
            {
                if (sum[j] > sum[j + 1])
                {
                    temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                    temp = sum[j];
                    sum[j] = sum[j + 1];
                    sum[j + 1] = temp;
                }
            }
        }
        for (i = 0; i < n; i++)
        {
            printf("%d ", a[ i]);  // 修改为输出空格分隔的数字
        }
        printf("\n");
    }
    return 0;
}

主要修改包括:
1. 内部循环条件判断改为  j < n - i - 1 ,修复了循环条件错误的问题;
2. 输出每个数字后加上空格,方便区分每个排序后的数字。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-18 14:58:52 | 显示全部楼层
你的代码中有一些小错误,我已经帮你修改了一下,可以试着运行一下看看:
#include <stdio.h>int main() {    int n, i, j, temp;    int a[11];    int sum[1100];    while (scanf("%d", &n) != EOF && n != 0) {        for (i = 0; i < n; i++) {            scanf("%d", &a[i]);        }        for (i = 0; i < n; i++) {            int num = 0;            int k = a[i];            while (k != 0) {                int j = k % 10;                k = k / 10;                num += j;            }            sum[i] = num;        }        for (i = 0; i < n - 1; i++) {            for (j = 0; j < n - i - 1; j++) {                if (sum[j] > sum[j + 1]) {                    temp = a[j];                    a[j] = a[j + 1];                    a[j + 1] = temp;                    temp = sum[j];                    sum[j] = sum[j + 1];                    sum[j + 1] = temp;                }            }        }        for (i = 0; i < n; i++) {            printf("%d ", a[i]);        }        printf("\n");    }    return 0;}
现在代码已经修改过了,应该可以按要求输出结果了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-23 15:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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