对于 [CK005加勒比海盗船-最优装载问] 代码的修正

代码骑士
优质创作者: 游戏开发技术领域
2023-01-03 14:28:05

源代码:

#include<stdio.h>
#include<algorithm>

int main()
{
	int c=25;//船载重量 
	int w[5]={5,5,5,5,5};//古董重量数组 
	std::sort(w,w+5);//默认将w数组按从小到大排序 
	int sum,n=0;//最大数量
	for(int i=0;i<5;i++)
	{
		if(sum>c) break;
		sum+=w[i];
		n++;
		printf("sum=%d,count=%d\n",sum,n);
	}
	printf("最大装载数量是:%d",n-1);
	return 0;
} 

测试样例:

答案明显错误。

错误原因是在sum=c时,输出的结果不能是n-1

printf("最大装载数量是:%d",n-1);

需要加一个判断:

#include<stdio.h>
#include<algorithm>

int main()
{
	int c=25;//船载重量 
	int w[5]={1,1,1,1,1};//古董重量数组 
	std::sort(w,w+5);//默认将w数组按从小到大排序 
	int sum,n=0;//最大数量
	for(int i=0;i<5;i++)
	{
		if(sum>c) break;
		sum+=w[i];
		n++;
		printf("sum=%d,count=%d\n",sum,n);
	}
	if(sum>c){
		printf("最大装载数量是:%d",n-1);
	}else if(sum<=c)
	{
		printf("最大装载数量是:%d",n);	
	}
	return 0;
} 

输出结果:

 

...全文
72 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

5

社区成员

发帖
与我相关
我的任务
社区描述
考研408:数据结构、计算机组成原理、操作系统、计算机网络
学习方法考研面试 其他
社区管理员
  • 代码骑士
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧