使用C语言做for循环嵌套练习。此次为个人练习,若有错误或需改进敬请提出。
要求:某人想将手中的一张面值100元的人民币换成10元、5元、2元和1元面值的票子。要求换正好40张,且每种票子至少一张。问:有几种换法?
第一步,我们需要考虑100元最多能换成几张10元的;100元最多能换成几张5元的;100元最多能换成几张2元的;100元最多能换成几张1元的。将这四个循环嵌套构成一个框架。
第二步,题目中是将100元换成10元、5元、2元和1元的人民币。因此,a张10元的人民币+b张5元的人民币+c张2元的人民币+d张1元的人民币=100元。
第三步,题中也提到这四种面值的人民币要求正好换40张。因此,a张+b张+c张+d张=40张。
第四步,判断第二步和第三步是否满足。若满足,则累加换法的次数,并将每种的情况打印出来。
代码如下:
#include <stdio.h>
int main() {
int a, b, c, d, sum, total, n = 0;
for (a = 1; a < 10; a++)
{
for (b = 1; b < 20; b++)
{
for (c = 1; c < 50; c++)
{
for (d = 1; d < 100; d++)
{