鱼C论坛

 找回密码
 立即注册
查看: 1337|回复: 5

[已解决]求数组中最小元素的值及其位置

[复制链接]
发表于 2020-5-19 18:01:30 | 显示全部楼层 |阅读模式

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

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

x
有一维整型数组a(长度为10),输入数组各元素的值,求数组中最小元素的值及其在数组中的位置。

输入格式:
输入10个整数,数之间用空格分隔

输出格式:
第一行输出最小值 第二行输出最小值在数组中的位置。如果有多个元素同为最小值,则输出这些元素的位置,每个位置之后加2个空格。

输入样例0:
1  4  -1  8  9   4  7   -1  12  -1
输出样例0:
-1
2  7  9  
输入样例1:
1  12   3   -4  5  6  7  8  9  10
输出样例1:
-4
3  


请问这个程序应该怎么写?
最佳答案
2020-5-19 18:38:40
本帖最后由 qiuyouzhi 于 2020-5-19 18:40 编辑
# include <stdio.h>

int main()
{
        int temp[120], pos[120];
        int cnt = 0;
        for (int i = 0; i < 10; i++)
                scanf("%d", &temp[i]);
        int min = temp[0];
        for (int i = 0; i < 10; i++)
        {
                if (temp[i] <= min)
                {
                        min = temp[i];
                        pos[cnt++] = i;
                }
        }
        printf("%d\n", min);
        for (int i = 0; i < cnt; i++)
                if (i == 0 && temp[i] != min)
                        continue;
                else
                        printf("%d  ", pos[i]);
        return 0;
 }  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-5-19 18:08:44 | 显示全部楼层
# include <stdio.h>

int main()
{
        int temp[120]; 
        for (int i = 0; i < 10; i++)
                scanf("%d", &temp[i]);
        int min = temp[0];
        int pos = 0;
        for (int i = 0; i < 10; i++)
        {
                if (temp[i] < min)
                {
                        min = temp[i];
                        pos = i;
                }
        }
        printf("%d\n", min);
        printf("%d\n", pos+1);
        return 0;
 } 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-19 18:31:07 | 显示全部楼层

想问一下“如果有多个元素同为最小值,则输出这些元素的位置,每个位置之后加2个空格。”这个这里怎么写
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-19 18:32:38 | 显示全部楼层
你今天学C了吗 发表于 2020-5-19 18:31
想问一下“如果有多个元素同为最小值,则输出这些元素的位置,每个位置之后加2个空格。”这个这里怎么写

噢,忘记了这件事
我改下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-19 18:38:40 | 显示全部楼层    本楼为最佳答案   
本帖最后由 qiuyouzhi 于 2020-5-19 18:40 编辑
# include <stdio.h>

int main()
{
        int temp[120], pos[120];
        int cnt = 0;
        for (int i = 0; i < 10; i++)
                scanf("%d", &temp[i]);
        int min = temp[0];
        for (int i = 0; i < 10; i++)
        {
                if (temp[i] <= min)
                {
                        min = temp[i];
                        pos[cnt++] = i;
                }
        }
        printf("%d\n", min);
        for (int i = 0; i < cnt; i++)
                if (i == 0 && temp[i] != min)
                        continue;
                else
                        printf("%d  ", pos[i]);
        return 0;
 }  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-19 18:45:47 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-13 19:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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