「已注销」 2022-05-29 13:28 采纳率: 91.2%
浏览 20
已结题

幂积序列,第22行,输出i时为什么要减1?

img


#include<stdio.h>
int main()
{
int a[10000];
int n,m,i,j=0;
for(i=1;i<200000000;i++)
{
n=i;
while(n%2==0)
n/=2;
while(n%3==0)
n/=3;
if(n==1)
a[++j]=i;
}
while(scanf("%d%d",&n,&m)!=EOF)
{
int p;
for(i=1;a[i]<=n;i++)
if(i==m)
p=a[i];
printf("%d\n",i-1);
printf("%d\n",p);
}
return 0;
}

  • 写回答

1条回答 默认 最新

  • 树下等苹果 2022-05-29 14:12
    关注

    因为你执行for(i=1;a[i]<=n;i++),会执行i++,即使是最后一次不满足条件a[i]<=n,也会执行i++,所以i比求的值大1,因此要减1

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月6日
  • 已采纳回答 5月29日
  • 创建了问题 5月29日

悬赏问题

  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏