当前位置: 首页 > article >正文

C语言:乘法口诀表的一些实现方法

一、优点

        1、有菜单

        2、可自定义大小

        3、可进行重复输入

二、缺点

        1、在 9 以内(包括 9 )的乘法口诀表才能正常左对齐输出

三、代码

        1、迭代法

#include <stdio.h>

void menu()
{
	printf("******************************\n");
	printf("***  是否要输出乘法口诀表  ***\n");
	printf("***          1、是         ***\n");
	printf("***          0、否         ***\n");
	printf("******************************\n");
}

void printMulTable()
{
	int n = 0;
	printf("请输入大小:");
	scanf("%d", &n);

	//用“迭代法”来输出乘法口诀表
	int i = 0;
	int j = 0;
	for (i = 1; i <= n; i++)
	{
		for (j = 1; j <= i; j++)
		{
			printf("%d*%d=%-2d\t", j, i, i * j);
		}
		printf("\n");
	}
}

int main()
{
	int input = 0;
	do
	{
		menu();//菜单

		printf("请输入:");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			printMulTable();
			break;
		case 0:
			printf("成功退出\n");
			break;
		default:
			printf("输入错误\n");
			break;
		}
	} while (input);

	return 0;
}

        2、递归法 + 迭代法

#include <stdio.h>

void menu()
{
	printf("******************************\n");
	printf("***  是否要输出乘法口诀表  ***\n");
	printf("***          1、是         ***\n");
	printf("***          0、否         ***\n");
	printf("******************************\n");
}

//用 “递归法” + “迭代法” 打印乘法表
void print(int n)
{
	if (n > 1)
	{
		print(n - 1);
	}
	int i = 0;
	for (i = 1; i <= n; i++)
	{
		printf("%d*%d=%-2d\t", i, n, i * n);
	}
	printf("\n");
}

void mulTable()
{
	int n = 0;
	printf("请输入大小:");
	scanf("%d", &n);
	print(n);
}

int main()
{
	int input = 0;
	do
	{
		menu();//菜单

		printf("请输入:");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			mulTable();//乘法口诀表
			break;
		case 0:
			printf("成功退出\n");
			break;
		default:
			printf("输入错误\n");
			break;
		}
	} while (input);

	return 0;
}

附:若有不足,望指出

^_^感谢^_^


http://www.kler.cn/a/301867.html

相关文章:

  • c# Encoding.GetEncoding
  • vue如何实现组件切换
  • 【C++】深入理解 C++ 优先级队列、容器适配器与 deque:实现与应用解析
  • kafka消费者出现频繁Rebalance
  • sql注入之二次注入(sqlilabs-less24)
  • 北京大学c++程序设计听课笔记101
  • springboot基础-logback组件配置使用
  • 2024年9月12日(k8s环境及测试 常用命令)
  • 康谋分享 | 汽车仿真与AI的结合应用
  • 1.SpringCloud与SpringCloud Alibaba
  • Java面试篇基础部分-Java中的异常以及异常处理
  • 初识爬虫3
  • 【区块链通用服务平台及组件】信息数据流转验真技术研究项目 | FISCO BCOS应用案例
  • HCIA--实验十一:单区域OSPF路由实验
  • 基于SpringBoot+Vue+MySQL的垃圾分类回收管理系统
  • 【菜菜的sklearn机器学习】(2)回归树
  • 设计模式 22 模板方法模式
  • electron 客户端 windows linux(麒麟V10)多系统离线打包 最新版 <一>
  • 【系统架构设计师】建造者模式(Builder Pattern)
  • Android通知——Notification
  • 【JUC并发编程系列】深入理解Java并发机制:从synchronized到CAS锁升级全过程(三、synchronized 前置知识)
  • SpringBoot教师招聘管理系统---附源码81097
  • ios调整启动图显示的时间
  • Java | Leetcode Java题解之第402题移掉K位数字
  • RabbitMQ 07 另两种集群方式 warren(主备模式),shovel(远程模式)
  • Java算法:二进制和位运算