excel函数怎么判断回文
时间:2022-04-25 04:30:11
excel函数怎么判断回文?使用公式判断单元格中的数据是否是回文。
所谓回文,是指单词或句子无论是从左向右读还是从右向左读,都是一样的。也就是说,属于回文的单词或句子是左右对称的。例如,单词“deed”、“madam”。
先不看答案,自已动手试一试。
公式
假设单词或句子在单元格A1中,那么可以使用公式:
=IF( SUMPRODUCT( ( MID(A1,ROW(OFFSET($A$1,,,LEN(A1))),1)= MID(A1,LEN(A1)-ROW(OFFSET($A$1,,,LEN(A1)))+1,1)) + 0 ) = LEN(A1), “这个是回文”,”No!”)
判断该单元格中的值是否是回文。
公式解析
1. 假设单元格A1中的数据是“madam”。很明显,这是个回文。
公式中的:
ROW(OFFSET($A$1,,,LEN(A1)))
OFFSET函数以单元格A1为起点扩展5个单元格(示例中LEN(A1)=5),因此其可解析为:
ROW($A$1:$A$5)
得到:
{1;2;3;4;5}
这样,公式中的:
MID(A1,ROW(OFFSET($A$1,,,LEN(A1))),1)
转换为:
MID(A1, {1;2;3;4;5},1)
得到:
{“m”;”a”;”d”;”a”;”m”}
再看公式中的:
MID(A1,LEN(A1)-ROW(OFFSET($A$1,,,LEN(A1)))+1,1)
可转换为:
MID(A1,LEN(A1)-{1;2;3;4;5}+1,1)
转换为:
MID(A1,5 -{1;2;3;4;5}+1,1)
转换为:
MID(A1,{5;4;3;2;1},1)
得到:
{“m”;”a”;”d”;”a”;”m”}
将两者相比较:
MID(A1,ROW(OFFSET($A$1,,,LEN(A1))),1)= MID(A1,LEN(A1)-ROW(OFFSET($A$1,,,LEN(A1)))+1,1)
即:
{“m”;”a”;”d”;”a”;”m”}={“m”;”a”;”d”;”a”;”m”}
得到:
{TRUE;TRUE;TRUE;TRUE;TRUE}
将上述结果代入公式:
=IF( SUMPRODUCT( ( MID(A1,ROW(OFFSET($A$1,,,LEN(A1))),1) = MID(A1,LEN(A1)-ROW(OFFSET($A$1,,,LEN(A1)))+1,1))+ 0 ) = LEN(A1), “这个是回文”, “No!”)
得到:
=IF( SUMPRODUCT( ({TRUE;TRUE;TRUE;TRUE;TRUE})+ 0 ) = LEN(A1), “这个是回文”, “No!”)
转换为:
=IF( SUMPRODUCT( {1;1;1;1;1} ) =LEN(A1), “这个是回文”, “No!”)
转换为:
=IF( 5 = LEN(A1), “这个是回文”,”No!”)
转换为:
=IF( 5 = 5,”这个是回文”, “No!”)
转换为:
=IF( TRUE ,”这个是回文”, “No!”)
得到:
这个是回文
2. 假设单元格A1中的数据是“excel”。很明显,这不是回文。
根据上面的分析可知,公式中的:
MID(A1,ROW(OFFSET($A$1,,,LEN(A1))),1)
将转换为:
{“e”;”x”;”c”;”e”;”l”}
公式中的:
MID(A1,LEN(A1)-ROW(OFFSET($A$1,,,LEN(A1)))+1,1)
将转换为:
{“l”;”e”;”c”;”x”;”e”}
两者比较:
MID(A1,ROW(OFFSET($A$1,,,LEN(A1))),1)= MID(A1,LEN(A1)-ROW(OFFSET($A$1,,,LEN(A1)))+1,1)
即:
{“e”;”x”;”c”;”e”;”l”}={“l”;”e”;”c”;”x”;”e”}
得到:
{FALSE;FALSE;TRUE;FALSE;FALSE}
代入主公式中,得到:
=IF( SUMPRODUCT( ({TRUE;TRUE;TRUE;TRUE;TRUE})+ 0 ) = LEN(A1), “这个是回文”, “No!”)
转换为:
=IF( SUMPRODUCT({0;0;1;0;0}) =LEN(A1), “这个是回文”, “No!”)
转换为:
=IF(1 = 5, “这个是回文”,”No!”)
显然得到:
No!
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Word2007中将图片设置“冲蚀”效果的操作方法
Win10怎么关闭笔记本触摸板?
![](https://img.aspxhome.com/file/2023/0/49370_0s.png)
如何给excel单元格插入批注
![](https://img.aspxhome.com/file/2023/2/a154762_0s.png)
excel表格怎么快速计算各快递件的邮费?
![](https://img.aspxhome.com/file/2023/2/42612_0s.jpg)
excel如何与VLOOKUP函数相反的左向查找公式
excel中YEAR函数的使用方法
Win10打不开192.168.1.1设置界面怎么处理?
![](https://img.aspxhome.com/file/2023/2/51852_0s.png)
WPS2016如何复制段落格式?
![](https://img.aspxhome.com/file/2023/7/a163727_0s.jpg)
excel表格还原全屏
WPS默认文件格式怎么修改
![](https://img.aspxhome.com/file/2023/0/a164110_0s.jpg)
Word 2007邮件合并-步骤5:最终合并
![](https://img.aspxhome.com/file/2023/6/23246_0s.jpg)
Win10怎么在桌面显示天气预报和时间?
![](https://img.aspxhome.com/file/2023/3/51303_0s.png)
Word怎么不让标点出现在下一行开头
![](https://img.aspxhome.com/file/2023/7/31907_0s.png)
C2). 2、回车得到结果21
介绍Word2007新增快速样式库教程
![](https://img.aspxhome.com/file/2023/0/19860_0s.png)
word 2016裁剪图片
![](https://img.aspxhome.com/file/2023/2/32782_0s.jpg)
word 2016如何为文档添加页眉和页脚
![](https://img.aspxhome.com/file/2023/4/32754_0s.jpg)
怎么添加word页眉横线?word页眉横线添加详细步骤
![](https://img.aspxhome.com/file/2023/7/29137_0s.png)
word标尺怎么调出来
![](https://img.aspxhome.com/file/2023/2/34792_0s.jpg)
excel2007怎么制作拼音田字格模板?
![](https://img.aspxhome.com/file/2023/6/40176_0s.jpg )