#include<stdio.h>int main()
{ int m,n,min,max,t,k,i,derta,f=0,l,b,h;
while((scanf("%d%d%d",&m,&n,&t))!=EOF&&0<m
&&0<n&&0<t&&m<10000&&n<10000&&t<1000
0)
{ i=0; l=0; f=0;
if(m==n)
{k=t/m; h=t%m; f=1; printf("%d %d\n",k,h); con
tinue;
}
min=(m>n?n:m); max=(n<m?m:n);
while(i*min+l*max<=t)
{while(i*min+l*max<=t)
{if(i*min+l*max==t)
{k=i+l; f=1; printf("%d 0\n",k);
break;
}
i++;
}
if(f==1)
break;
l++; i=0;
}
if(f!=1)
{ l=0; i=0; h=t;
while(i*min+l*max<=t)
{while(i*min+l*max<=t)
{ b=t-i*min-l*max;
if(h>b)
{ h=b; k=i+l;
}
i++;
}
i=0; l++;
}
printf("%d %d\n",k,h);
}
}
return 0;
}
编程出来就是过不了,部分正确
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 技术专家团-小桥流水 2021-11-01 14:14关注
你的代码看着太费劲了,给你重写了一下,有注释,如有帮助,请帮忙采纳一下,谢谢。
代码
#include <stdio.h> int main() { int m,n,t; int i,j,l,min,sum; while( scanf("%d %d %d",&m,&n,&t) != EOF) //m n t的范围不需要写在这里,输入的时候注意即可 { if (m==n) { printf("%d %d\n",t/m,t%m); continue; } //让m是大值,n是小值 if(m<n) { l = m; m=n; n=l; } min = m; //min用来记录剩余的最小时间,开始的时候让它等于一个比较大的值 for (i=t/n;i>=0;i--) { j = (t - i*n)/m; l = t - i*n - j*m; if(j >=0 && l>=0 && l < min) { sum = i+j; min = l; } } printf("%d %d\n",sum,min); } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
- ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
- ¥50 opencv4nodejs 如何安装
- ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
- ¥15 nginx反向代理获取ip,java获取真实ip
- ¥15 eda:门禁系统设计
- ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
- ¥15 376.1电表主站通信协议下发指令全被否认问题
- ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
- ¥15 复杂网络,变滞后传递熵,FDA