O_o180 2022-04-11 04:40 采纳率: 100%
浏览 66
已结题

问题是 pta天梯赛的善良 这么做哪里错了?

#include<stdio.h>
int main()
{
int N,a,min,max,n=1,m=1,x=1000000,y=0;
scanf("%d\n",&N);
scanf("%d",&a);
if(a<=x&&a>y)
max=min=a;
for(int i=1;i<N;i++){
scanf("%d",&a);
if(max<a) max=a;
if(max==a) n++;
if(min>a) min=a;
if(min==a) m++;
}
printf("%d %d\n",min,m);
printf("%d %d",max,n);
return 0;
}

  • 写回答

1条回答 默认 最新

  • a5156520 2022-04-11 06:48
    关注

    主要问题,可能是判断最大值和最小值的地方出了点问题,因为最大值和最小值需要在所有输入完成后才能判断哪些最大,哪些最小,
    在输入的同时既计算最大最小值,又统计最大和最小值的个数,似乎是难以同时完成,修改如下:

    1. #include<stdio.h>
    2. int main()
    3. {
    4. //根据N的最大值创建数组a,根据N的最大值设置min的初始值为10^6,根据是正整数,设置m的初始值0
    5. int N,a[20000],min=1000000,max=0,n=0,m=0;
    6. int i;
    7. scanf("%d",&N);
    8. // scanf("%d",&a);
    9. // if(a<=x&&a>y)
    10. // max=min=a;
    11. //获取输入,然后判断输入中的最大值和最小值
    12. for(i=0;i<N;i++){
    13. scanf("%d",&a[i]);
    14. if(max<a[i]) max=a[i];
    15. // if(max==a) n++;
    16. if(min>a[i]) min=a[i];
    17. // if(min==a) m++;
    18. }
    19. //通过再次遍历,统计最大值max和最小值min的人数
    20. for(i=0;i<N;i++){
    21. if(a[i]==max){
    22. m++;
    23. }
    24. if(a[i]==min){
    25. n++;
    26. }
    27. }
    28. //打印结果
    29. printf("%d %d\n",min,n);
    30. printf("%d %d",max,m);
    31. return 0;
    32. }

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    a5156520 2024-12-21 11:58

    如果一定要在输入的同时,计算最大值和最小值的个数的话,一个折衷办法是,每次输入完一个整数,则计算一次最大值和最小值的个数。

    修改如下:

    1. #include<stdio.h>
    2. int main() {
    3. //根据N的最大值创建数组a,根据N的最大值设置min的初始值为10^6,根据是正整数,设置m的初始值0
    4. int N,a[20000],min=1000000,max=0,n=0,m=0;
    5. int i,j;
    6. scanf("%d",&N);
    7. //获取输入,然后判断输入中的最大值和最小值
    8. for(i=0; i<N; i++) {
    9. scanf("%d",&a[i]);
    10. if(max<a[i]) {
    11. max=a[i];
    12. }
    13. if(min>a[i]) {
    14. min=a[i];
    15. }
    16. // 如果一定要在输入的同时计算最大值和最小值的个数,
    17. // 可以在每次输入完一个整数, 则计算一次最大值和最小值的个数
    18. m=0;
    19. for(j=0; j<=i; j++) {
    20. if(max==a[j]) {
    21. m++;
    22. //printf("max=%d, m=%d, i=%d\n",max,m,i);
    23. }
    24. }
    25. n=0;
    26. for(j=0; j<=i; j++) {
    27. if(min==a[j]) {
    28. n++;
    29. //printf("min=%d,n=%d, i=%d\n",min,n,i);
    30. }
    31. }
    32. }
    33. //打印结果
    34. printf("%d %d\n",min,n);
    35. printf("%d %d",max,m);
    36. return 0;
    37. }

    img

    回复
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 12月4日
  • 已采纳回答 11月27日
  • 创建了问题 4月11日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部