How to make a Palindrome Checker
37 次查看(过去 30 天)
显示 更早的评论
I need to write a code that checks to see if an input is a palindrome-same backwards as forwards, for instance madam or rotor.
I need to use the "programming method" which means I can't use any functions with str, eval, flip or printf. I don't want the answer, but just a place to start on how to build this code. Note, this isn't homework, just a practice question.
0 个评论
采纳的回答
Image Analyst
2015-12-5
I get no such problem. Did you pass in rotor or 'rotor'? You probably forgot the quotes around it, because this works fine for me
output = isPalindrome('rotor')
If the function is
function output = isPalindrome(yourString)
lastIndex=floor(length(yourString)/2);
for k=1:lastIndex
if yourString(k)~=yourString(end+1-k)
output = false;
else
output = true;
end
end
You also didn't use the debugger like I recommended or else you would have found out that you need to use (end+1-k) instead of (lastIndex+1-k).
8 个评论
Image Analyst
2023-5-1
@Kashiraj it simply compares the first letter to the last letter, the second letter to the next to the last letter, and so on. Just think how you would describe it yourself if you had to explain it to someone.
更多回答(1 个)
Walter Roberson
2015-12-5
The first point is X(1). The last point is X(end)
The second point is X(2). The second last point is X(end-1)
The third point is X(3). The third last point is X(end-2)
So for the K'th point, which point is the K'th last point?
9 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Logical 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!