算法分析的
2023-12-26 23:31:49
??(1)一个顾客买了价值x元的商品(不考虑角、分),并将y元的钱交给售货员:编写代码:在各种币值的钱都很充分的情况下,使售货员能用张数最少的钱币找给顾客
#include<stdio.h>
int main()
{
int i = 0, j = 0, x = 0, y = 0, z = 0, a = 0, b[7] = { 0,50,20,10,2,1 }, s[7] = { 0 };//i,j用来循环计数,x为应付金额,y为实付金额,z为应找金额,a用来传参,b数组表示钱币的面值s数组用来存放找零每种币值的张数
printf("请输入应付金额:\n");
scanf_s("%d", &x, sizeof(x));
printf("请输入实付金额:\n");
scanf_s("%d", &y, sizeof(y));
while (x > y)//非法输入判断
{
printf("非法数据请重新输入xy的值:");
scanf_s("%d", &x, sizeof(x));
scanf_s("%d", &y, sizeof(y));
}
z = y - x;
printf("找零:%d\n", z);
for (i = 1; i < 6; i++)
{
a = z / b[i];//b[1]=50从最大面值为50开始对找零金额取整计算50元的张数,以此类推
s[i] = a;
z = z - a * b[i];//减去确定张数的钱币金额,剩余部分进入循环语句判断下一种面值的钱币数
}
for (i=1;i<=6;i++)//打印
{
if(s[i]>0)
{
printf("%d元%d张\t",b[i],s[i]);
}
}
return 1;
}
?<1>正确输入运行结果展示
<2>非法输入运行结果展示
(2)将输入数字编号332.....翻译为英文编号three?three two.....
#include<stdio.h>
int main()
{
int i = 0, j = 0, ind1 = 0, ind2 = 0;
int a[10] = {0};
char eng[10][6] = { "one","two","three","four","five","six","seven","eight","nine" };
printf("输入一个数ind1:");
scanf_s("%d", &ind1, sizeof(ind1));
while(ind1 >0)
{//例:ind1=326
ind2 = ind1 % 10;//先将输入数值个位对十取余,ind2=6
a[i] = ind2;//将取余得到的个位数数值存入数组a[i]中,注意此处排列顺序为个、十、百....a[0]=6
ind1 = ind1 / 10;//将对10取余后的数再对10取整,ind1=32
i++;
}
for (; i >= 0; i--)//因为a[i]数组存放顺序为个、十、百....例:623,所以要倒着输出为326
{
j = a[i-1]-1;
printf("%s ", eng[j]);//%输出为一维,这个地方输出用eng[j]就好,eng[j][6]反而会出错,因为eng[j][6]为二维数组
}
return 1;
}
?<1>输出结果展示
文章来源:https://blog.csdn.net/qq_67109227/article/details/135232591
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!