c++:通讯录的实现

news2024/11/27 16:48:10

大家可以先下载一下这篇文章的资源绑定的exe文件(免费),体验下通讯录是如何运行的。

目录

完整代码

整体思路

功能主体部分

菜单 

创建联系人结构体和通讯录的结构体

各个函数功能实现部分

 添加联系人

显示联系人

删除联系人

查找联系人

修改联系人

清空联系人


完整代码

#include<iostream>
#include<string>
#define MAX 1000
using namespace std;
//菜单界面
void menu()
{
	cout << "**************************" << endl;
	cout << "*****  1.添加联系人  *****" << endl;
	cout << "*****  2.显示联系人  *****" << endl;
	cout << "*****  3.删除联系人  *****" << endl;
	cout << "*****  4.查找联系人  *****" << endl;
	cout << "*****  5.修改联系人  *****" << endl;
	cout << "*****  6.清空联系人  *****" << endl;
	cout << "*****  0.退出通讯录  *****" << endl;
	cout << "**************************" << endl;
}
//设计联系人的结构体
struct Person
{
	string m_Name;//姓名
	int m_Sex;//1.男 2.女
	int m_Age;//年龄
	string m_Phone;//电话
	string m_Addr;//地址

};
//通讯录的结构体
struct Addressbooks
{
	//通讯录中保存的联系人数组
	struct Person personArray[MAX];

	//通讯录中当前记录联系人个数
	int m_Size;
};
//1.添加联系人
void addPerson(Addressbooks* abs)
{
	//判断通讯录是否已满,如果满了就不再添加
	if (abs->m_Size==MAX)
	{
		cout << "通讯录以满,无法添加!" << endl;
	}
	else
	{
		//添加具体联系人
		//姓名
		string name;
		cout << "请输入姓名: " << endl;
		cin >> name;
		abs->personArray[abs->m_Size].m_Name = name;
		//性别
		cout << "请输入性别: " << endl;
		cout << "1--男" << endl;
		cout << "2--女" << endl;
		int sex = 0;

		while (true)
		{
			//如果输入的是1或者2可以退出循环
			//如果不是就重新输入
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->personArray[abs->m_Size].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入" << endl;
		}
		//年龄
		cout << "请输入年龄: " << endl;
		int age = 0;
		cin >> age;
		abs->personArray[abs->m_Size].m_Age = age;
		//电话
		cout << "请输入电话: " << endl;
		string phone;
		cin >> phone;
		abs->personArray[abs->m_Size].m_Phone = phone;

		//住址
		cout << "请输入家庭住址: " << endl;
		string address;
		cin >> address;
		abs->personArray[abs->m_Size].m_Addr = address;

		//更新通讯录人数
		abs->m_Size++;
		cout << "添加成功" << endl;
		system("pause");
		system("cls");
	}
}

//2.显示所有联系人
void showPerson(Addressbooks* abs)
{
	//判断通讯录中的人数是否为0,如果为0,提示记录为空
	//如果不为0,显示记录的联系人信息
	if (abs->m_Size == 0)
	{
		cout << "当前记录为空" << endl;
	}
	else
	{
		for (int i = 0; i < abs->m_Size; i++)
		{
			cout << "姓名: " << abs->personArray[i].m_Name << "\t";
			cout << "性别: " << (abs->personArray[i].m_Sex ==1?"男":"女") << "\t";
			cout << "年龄: " << abs->personArray[i].m_Age << "\t";
			cout << "电话: " << abs->personArray[i].m_Phone << "\t";
			cout << "住址: " << abs->personArray[i].m_Addr << endl;
		}
	}
	system("pause");
	system("cls");
}

//检测联系人是否存在,如果存在,返回联系人所在数组中的具体位置,不存在则返回-1;
int isExist(Addressbooks* abs, string name)
{
	for (int i = 0; i < abs->m_Size; i++)
	{
		//找到用户输入的姓名了
		if (abs->personArray[i].m_Name == name)
		{
			return i;//找到了,返回这个人在数组中的下标编号
		}
	}
	return -1;
}

//3.删除指定的联系人
void deletePerson(Addressbooks* abs)
{
	cout << "请输入您要删除的联系人" << endl;

	string name;
	cin >> name;
	//ret==-1,未查到
	//ret!=-1,查到了
	int ret=isExist(abs, name);

	if (ret != -1)
	{
		for (int i = ret; i < abs->m_Size; i++)
		{
			abs->personArray[i] = abs->personArray[i + 1];
		}
		abs->m_Size--;//更新通讯录中的人员数
		cout << "删除成功" << endl;
	}
	else
	{
		cout << "查无此人 " << endl;
	}
	system("pause");
	system("cls");
}

//4.查找指定联系人信息
void findPerson(Addressbooks*abs)
{
	cout << "请输入你要查找的联系人"<<endl;
	string name;
	cin >> name;

	//判断联系人是否存在
	int ret=isExist(abs, name);
	if (ret != -1)
	{
		cout << "姓名: " << abs->personArray[ret].m_Name << "\t";
		cout << "性别: " << (abs->personArray[ret].m_Sex == 1 ? "男" : "女") << "\t";
		cout << "年龄: " << abs->personArray[ret].m_Age << "\t";
		cout << "电话: " << abs->personArray[ret].m_Phone << "\t";
		cout << "住址: " << abs->personArray[ret].m_Addr << endl;
	}
	else
	{
		cout << "查无此人" << endl;
	}
	system("pause");
	system("cls");
}

//5.修改指定联系人信息
void modifPerson(Addressbooks* abs)
{
	cout << "请输入您要修改的联系人" << endl;
	string name;
	cin >> name;

	int ret = isExist(abs, name);
	if (ret != -1)
	{
		//姓名
		string name;
		cout << "请输入修改后的姓名: " << endl;
		cin >> name;
		abs->personArray[ret].m_Name = name;
		//性别
		cout << "请输入性别: " << endl;
		cout << "1--男" << endl;
		cout << "2--女" << endl;
		int sex = 0;

		while (true)
		{
			cin >> sex;
			if (sex == 1 || sex == 2)
			{
				abs->personArray[ret].m_Sex = sex;
				break;
			}
			cout << "输入有误,请重新输入" << endl;
		}
		//年龄
		cout << "请输入年龄: " << endl;
		int age = 0;
		cin >> age;
		abs->personArray[ret].m_Age = age;

		//电话
		cout << "请输入联系电话: " << endl;
		string phone;
		cin >> phone;
		abs->personArray[ret].m_Phone = phone;

		//住址
		cout << "请输入家庭住址: " << endl;
		string address;
		cin >> address;
		abs->personArray[ret].m_Addr = address;

		cout << "修改成功" << endl;
	}
	else
	{
		cout << "查无此人" << endl;
	}
	system("pause");
	system("cls");
}

//6.清空联系人
void cleanPerson(Addressbooks* abs)
{
	abs->m_Size = 0;//讲当前记录的联系人数量置为0
	cout << "通讯录已清空" << endl;
	system("pause");
	system("cls");
}
int main()
{
	//创建通讯录结构体变量
	Addressbooks abs;
	//初始化通讯录中当前人员个数
	abs.m_Size = 0;

     int select = 0;//选择
	while (true)
	{
		//菜单调用
		menu();
		cout << "选择功能(0-6)" << endl;
		cin >> select;
		switch (select)
		{
		//1.添加联系人
		case 1:
			addPerson(&abs);//利用地址传递可以修饰实参
			break;
		//2.显示联系人
		case 2:
			showPerson(&abs);
			break;
		//3.删除联系人
		case 3:
			deletePerson(&abs);
			break;
		//4.查找联系人
		case 4:
			findPerson(&abs);
			break;
		//5.修改联系人
		case 5:
			modifPerson(&abs);
			break;
		//6.清空联系人
		case 6:
			cleanPerson(&abs);
			break;
		//0.退出通讯录
		case 0:
			cout << "欢迎下次使用" << endl;
			system("pause");//按下任意键退出代码
			return 0;
			break;
		default:
			cout << "输入不在选项内,请重新输入" << endl;
			break;
		}
	}
	system("pause");
	return 0;
}

整体思路

  1. 显示菜单
  2. 创建通讯录的结构体(嵌套联系人的结构体数组+联系人个数)
  3. 根据菜单建立选择分支
  4. 完善各个分支的内容

功能主体部分

int main()
{
	//创建通讯录结构体变量
	Addressbooks abs;
	//初始化通讯录中当前人员个数
	abs.m_Size = 0;

     int select = 0;//选择
	while (true)
	{
		//菜单调用
		menu();
		cout << "选择功能(0-6)" << endl;
		cin >> select;
		switch (select)
		{
		//1.添加联系人
		case 1:
			addPerson(&abs);//利用地址传递可以修饰实参
			break;
		//2.显示联系人
		case 2:
			showPerson(&abs);
			break;
		//3.删除联系人
		case 3:
			deletePerson(&abs);
			break;
		//4.查找联系人
		case 4:
			findPerson(&abs);
			break;
		//5.修改联系人
		case 5:
			modifPerson(&abs);
			break;
		//6.清空联系人
		case 6:
			cleanPerson(&abs);
			break;
		//0.退出通讯录
		case 0:
			cout << "欢迎下次使用" << endl;
			system("pause");//按下任意键退出代码
			return 0;
			break;
		default:
			cout << "输入不在选项内,请重新输入" << endl;
			break;
		}
	}
	system("pause");
	return 0;
}

菜单 

void menu()
{
	cout << "**************************" << endl;
	cout << "*****  1.添加联系人  *****" << endl;
	cout << "*****  2.显示联系人  *****" << endl;
	cout << "*****  3.删除联系人  *****" << endl;
	cout << "*****  4.查找联系人  *****" << endl;
	cout << "*****  5.修改联系人  *****" << endl;
	cout << "*****  6.清空联系人  *****" << endl;
	cout << "*****  0.退出通讯录  *****" << endl;
	cout << "**************************" << endl;
}

创建联系人结构体和通讯录的结构体

struct Person
{
	string m_Name;//姓名
	int m_Sex;//1.男 2.女
	int m_Age;//年龄
	string m_Phone;//电话
	string m_Addr;//地址

};
//通讯录的结构体
struct Addressbooks
{
	//通讯录中保存的联系人数组
	struct Person personArray[MAX];

	//通讯录中当前记录联系人个数
	int m_Size;
};

各个函数功能实现部分

  1.  添加联系人

    //1.添加联系人
    void addPerson(Addressbooks* abs)
    {
    	//判断通讯录是否已满,如果满了就不再添加
    	if (abs->m_Size == MAX)
    	{
    		cout << "通讯录以满,无法添加!" << endl;
    	}
    	else
    	{
    		//添加具体联系人
    		//姓名
    		string name;
    		cout << "请输入姓名: " << endl;
    		cin >> name;
    		abs->personArray[abs->m_Size].m_Name = name;
    		//性别
    		cout << "请输入性别: " << endl;
    		cout << "1--男" << endl;
    		cout << "2--女" << endl;
    		int sex = 0;
    
    		while (true)
    		{
    			//如果输入的是1或者2可以退出循环
    			//如果不是就重新输入
    			cin >> sex;
    			if (sex == 1 || sex == 2)
    			{
    				abs->personArray[abs->m_Size].m_Sex = sex;
    				break;
    			}
    			cout << "输入有误,请重新输入" << endl;
    		}
    		//年龄
    		cout << "请输入年龄: " << endl;
    		int age = 0;
    		cin >> age;
    		abs->personArray[abs->m_Size].m_Age = age;
    		//电话
    		cout << "请输入电话: " << endl;
    		string phone;
    		cin >> phone;
    		abs->personArray[abs->m_Size].m_Phone = phone;
    
    		//住址
    		cout << "请输入家庭住址: " << endl;
    		string address;
    		cin >> address;
    		abs->personArray[abs->m_Size].m_Addr = address;
    
    		//更新通讯录人数
    		abs->m_Size++;
    		cout << "添加成功" << endl;
    		system("pause");
    		system("cls");
    	}
    }

  2. 显示联系人

    //2.显示所有联系人
    void showPerson(Addressbooks* abs)
    {
    	//判断通讯录中的人数是否为0,如果为0,提示记录为空
    	//如果不为0,显示记录的联系人信息
    	if (abs->m_Size == 0)
    	{
    		cout << "当前记录为空" << endl;
    	}
    	else
    	{
    		for (int i = 0; i < abs->m_Size; i++)
    		{
    			cout << "姓名: " << abs->personArray[i].m_Name << "\t";
    			cout << "性别: " << (abs->personArray[i].m_Sex == 1 ? "男" : "女") << "\t";
    			cout << "年龄: " << abs->personArray[i].m_Age << "\t";
    			cout << "电话: " << abs->personArray[i].m_Phone << "\t";
    			cout << "住址: " << abs->personArray[i].m_Addr << endl;
    		}
    	}
    	system("pause");
    	system("cls");
    }
    
    //检测联系人是否存在,如果存在,返回联系人所在数组中的具体位置,不存在则返回-1;
    int isExist(Addressbooks* abs, string name)
    {
    	for (int i = 0; i < abs->m_Size; i++)
    	{
    		//找到用户输入的姓名了
    		if (abs->personArray[i].m_Name == name)
    		{
    			return i;//找到了,返回这个人在数组中的下标编号
    		}
    	}
    	return -1;
    }
    

  3. 删除联系人

    //3.删除指定的联系人
    void deletePerson(Addressbooks* abs)
    {
    	cout << "请输入您要删除的联系人" << endl;
    
    	string name;
    	cin >> name;
    	//ret==-1,未查到
    	//ret!=-1,查到了
    	int ret = isExist(abs, name);
    
    	if (ret != -1)
    	{
    		for (int i = ret; i < abs->m_Size; i++)
    		{
    			abs->personArray[i] = abs->personArray[i + 1];
    		}
    		abs->m_Size--;//更新通讯录中的人员数
    		cout << "删除成功" << endl;
    	}
    	else
    	{
    		cout << "查无此人 " << endl;
    	}
    	system("pause");
    	system("cls");
    }

  4. 查找联系人

    //4.查找指定联系人信息
    void findPerson(Addressbooks* abs)
    {
    	cout << "请输入你要查找的联系人" << endl;
    	string name;
    	cin >> name;
    
    	//判断联系人是否存在
    	int ret = isExist(abs, name);
    	if (ret != -1)
    	{
    		cout << "姓名: " << abs->personArray[ret].m_Name << "\t";
    		cout << "性别: " << (abs->personArray[ret].m_Sex == 1 ? "男" : "女") << "\t";
    		cout << "年龄: " << abs->personArray[ret].m_Age << "\t";
    		cout << "电话: " << abs->personArray[ret].m_Phone << "\t";
    		cout << "住址: " << abs->personArray[ret].m_Addr << endl;
    	}
    	else
    	{
    		cout << "查无此人" << endl;
    	}
    	system("pause");
    	system("cls");
    }

  5. 修改联系人

    //5.修改指定联系人信息
    void modifPerson(Addressbooks* abs)
    {
    	cout << "请输入您要修改的联系人" << endl;
    	string name;
    	cin >> name;
    
    	int ret = isExist(abs, name);
    	if (ret != -1)
    	{
    		//姓名
    		string name;
    		cout << "请输入修改后的姓名: " << endl;
    		cin >> name;
    		abs->personArray[ret].m_Name = name;
    		//性别
    		cout << "请输入性别: " << endl;
    		cout << "1--男" << endl;
    		cout << "2--女" << endl;
    		int sex = 0;
    
    		while (true)
    		{
    			cin >> sex;
    			if (sex == 1 || sex == 2)
    			{
    				abs->personArray[ret].m_Sex = sex;
    				break;
    			}
    			cout << "输入有误,请重新输入" << endl;
    		}
    		//年龄
    		cout << "请输入年龄: " << endl;
    		int age = 0;
    		cin >> age;
    		abs->personArray[ret].m_Age = age;
    
    		//电话
    		cout << "请输入联系电话: " << endl;
    		string phone;
    		cin >> phone;
    		abs->personArray[ret].m_Phone = phone;
    
    		//住址
    		cout << "请输入家庭住址: " << endl;
    		string address;
    		cin >> address;
    		abs->personArray[ret].m_Addr = address;
    
    		cout << "修改成功" << endl;
    	}
    	else
    	{
    		cout << "查无此人" << endl;
    	}
    	system("pause");
    	system("cls");
    }
    

  6. 清空联系人

    //6.清空联系人
    void cleanPerson(Addressbooks* abs)
    {
    	abs->m_Size = 0;//讲当前记录的联系人数量置为0
    	cout << "通讯录已清空" << endl;
    	system("pause");
    	system("cls");
    }

    如果写在同一个文件中,会十分拥挤,我们可以新建一个函数定义的文件在源文件(后缀.cpp)中,函数声明的文件在头文件(后缀.h)中。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1399505.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

pytest实现多进程与多线程运行超好用的插件

前言 如果想分布式执行用例&#xff0c;用例设计必须遵循以下原则&#xff1a; 1、用例之间都是独立的&#xff0c; 2、用例a不要去依赖用例b 3、用例执行没先后顺序&#xff0c; 4、随机都能执行每个用例都能独立运行成功每个用例都能重复运行&#xff0c;不影响其它用例 这…

顶顶通用户申请和安装 空号识别 模块流程

一、申请 空号识别 授权 打开网址&#xff1a;http://my.ddrj.com&#xff0c;注册并登录。 点击“我的授权” -> “申请授权” &#xff08;根据负责人的要求选择“在线”或是“离线”&#xff09;。 找到名称为空号识别的授权并点击“加号”图标打开授权&#xff0c;然…

Hive数仓框架详解

Hive框架详解 1、Hive的介绍 ​ Hive是基于Hadoop的一个数据仓库工具&#xff0c;可以将结构化的数据文件映射为一张数据库表&#xff0c;并提供类SQL查询功能。 ​ 本质是将SQL转换为MapReduce程序。 ​ 主要用途&#xff1a;用来做离线数据分析&#xff0c;比直接用MapRed…

百度大脑 使用

百度大脑&#xff1a; 官方网址&#xff1a;https://ai.baidu.com/ 文档中心&#xff1a;https://ai.baidu.com/ai-doc 体验中心&#xff1a;https://ai.baidu.com/experience 百度大脑则是百度AI核心技术引擎&#xff0c;它包括基础层、感知层、认知层和安全&#xff0c;是百…

Codeforces Round 803 (Div. 2) E. PermutationForces II(思维题 位置序列)

题目 给定长为n(n<2e5)的两个序列a和b&#xff0c; a为n的一个排列&#xff0c; b也为n的一个排列&#xff0c;但有一些位置被-1替换了&#xff0c;保证没被替换的位置在[1,n]之间且两两不同 你有一个距离最大限制s&#xff0c;你可以执行n次操作&#xff0c; 第i次操作…

【爬虫实战】2024知乎热榜可视化爬取

项目功能简介&#xff1a; 1.支持配置&#xff1b; 2.单次爬取&#xff1b; 3.循环爬取&#xff1b; 4.爬虫暂停&#xff1b; 5.数据清除&#xff1b; 6.数据保存到csv文件&#xff1b; 7.程序支持打包成exe文件&#xff1b; 8.项目操作说明文档&#xff1b; 9.模块封装到类&a…

全自动网页制作系统流星全自动网页生成系统重构版输入网页信息即可制作

源码优点: 所有模板经过精心审核与修改&#xff0c;完美兼容小屏手机大屏手机&#xff0c;以及各种平板端、电脑端和360浏览器、谷歌浏览器、火狐浏览器等等各大浏览器显示。 免费制作 为用户使用方便考虑&#xff0c;全自动网页制作系统无需繁琐的注册与登入&#xff0c;直接…

大创项目推荐 疫情数据分析与3D可视化 - python 大数据

文章目录 0 前言1 课题背景2 实现效果3 设计原理4 部分代码5 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 大数据全国疫情数据分析与3D可视化 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff0…

AWS CI/CD之二:配置CodeDeploy

问题 前面一篇文章介绍了CodeBuild中构建一个Java的Maven项目。在这个基础上面&#xff0c;我们继续AWS CI/CD工作流构建之路。 1.配置CodePipeline简配版 这里主要是利用CodePipeline配置之前的CodeBuild项目&#xff0c;以便生产出需要部署的jar文件和CodeDeploy需要用到相…

手把手教你薅熊链Berachain测试网空投

Berachain&#xff0c;这名字响当当&#xff01;是基于流动性证明的高性能区块链&#xff0c;结合了Tendermint和流动性共识证明&#xff0c;还采用了Celestia作为DA层。这速度快、成本低、确定性高&#xff0c;简直就是未来的大热门&#xff01;你知道吗&#xff1f;这家公司可…

异步编程Completablefuture使用详解----入门篇

JDK版本&#xff1a;jdk17 IDEA版本&#xff1a;IntelliJ IDEA 2022.1.3 文章目录 一、CompletableFuture是什么&#xff1f;二、为什么要使用CompletableFuture&#xff1f;2.1 工具类准备2.2 Future的局限性2.3 CompletableFuture的优势 三、如何使用CompletableFuture?3.1 …

Web3艺术市场:NFT与数字创作的结合

在数字时代&#xff0c;随着区块链技术的崛起&#xff0c;一种新型数字资产&#xff0c;非同质化代币&#xff08;NFT&#xff09;&#xff0c;正逐渐改变传统艺术市场的格局。这种数字化的艺术品售卖方式成为了Web3艺术市场的代表&#xff0c;推动着数字创作与艺术市场的结合。…

day05_java中的流程控制

概述 在一个程序执行的过程中&#xff0c;各条语句的执行顺序对程序的结果是有直接影响的。所以&#xff0c;我们必须清楚每条语句的执 行流程。而且&#xff0c;很多时候要通过控制语句的执行顺序来实现我们想要的功能。 流程控制语句又分为&#xff1a; 顺序结构 丶分支结构丶…

性能优化-HVX架构简介

来自 「发表于知乎专栏《移动端算法优化》」 本文主要介绍Hexagon DSP的HVX技术&#xff0c;旨在通过简单的语言讲清HVX技术。 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;高性能&#xff08;HPC&#xff09;开…

vue3 + antd 封装动态表单组件(一)

前置条件&#xff1a; vue版本 v3.3.11 ant-design-vue版本 v4.1.1 创建动态组件配置文件config.js import { Input, Textarea, InputNumber, Select, RadioGroup, CheckboxGroup, DatePicker } from ant-design-vue;// 表单域组件类型 export const componentsMap {Text: …

编译poco库出现的问题及其解决办法

作者&#xff1a;朱金灿 来源&#xff1a;clever101的专栏 为什么大多数人学不会人工智能编程&#xff1f;>>> 使用vs2015编译poco库出现问题&#xff1a;error C3688: invalid literal suffix ‘I64_FMT’; literal operator or literal operator template ‘opera…

大模型:我也会自监督学习~

前言 当下大模型的能力已经很强了&#xff0c;但是将来我们想要的是能力更强的大模型&#xff0c;其最好能够处理各种复杂问题也即强对齐模型。 之前大模型训练的监督信号主要来源于人类反馈&#xff0c;但是如果想要训练一个强对齐模型必然就需要一个对应的强监督信号&#…

第二篇【传奇开心果系列】Vant 开发移动应用:开发常见页面

传奇开心果博文系列 Vant of Vue 开发移动应用示例系列博文博文目录一、常见页面的重要作用二、常见页面介绍三、分别示例代码四、常见页面样式示例代码五、主要知识点总结 Vant of Vue 开发移动应用示例系列博文 博文目录 一、常见页面的重要作用 常见页面在移动应用中扮演…

手把手教你如何快速定位bug,如何编写测试用例,快来观摩......

手把手教你如何快速定位bug,如何编写测试用例,快来观摩......手把手教你如何快速定位bug,如何编写测试用例,快来观摩......作为一名测试人员如果连常见的系统问题都不知道如何分析&#xff0c;频繁将前端人员问题指派给后端人员&#xff0c;后端人员问题指派给前端人员&#xf…

算法第二十一天-丑数

丑数 题目要求 解题思路 首先判断数字是不是为0或者负数&#xff0c;两者均不可能成为丑数&#xff1b; 之后对n进行不断整除&#xff0c;直到无法除尽为止。 简单判断最后的数是不是1即可。 代码 class Solution:def isUgly(self, n: int) -> bool:if n<0:return Fa…