同学前阵子面试碰到的面试题,回来交流了一下后总结了几种答案,题目就是写一个函数,做到输入1则输出0,输入0则输出1,面试时的要求是不需要考虑错误处理。面试官说是可以有二十多种解法的,暂时只想到了下面一些,部分解法总的思想应该差别不大。
假设该函数输入变量类型和返回变量类型均为int。
方法一:最先想到的就是利用if-else来处理,逻辑简单且错误处理很容易加上去,代码如下。
#include <iostream>
using namespace std;
int my_reverse(int in)
{
if(1 == in)
return 0;
else if(0 == in)
return 1;
else
{
cout<<"invalid input"<<endl;
exit(1);
}
}
int main()
{
int input;
cin>>input;
cout<<my_reverse(input)<<endl;
return 0;
}
方法二:跟方法一差不多,用while循环来做,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
while(1 == in)
return 0;
return 1;
}
方法三:使用switch,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
switch(in)
{
case 1: return 0;
case 0: return 1;
default: cout<<"invalid input"<<endl;
exit(1);
}
}
方法四:使用三元运算符,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
return 1 == in ? 0 : 1;
}
方法五:将传入的值减1取绝对值,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
return abs(in - 1);
}
方法六:将传入的值加1取除以2的余数,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
return (in + 1) % 2;
}
方法七:与1异或,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
return in^1;
}
方法八:取反,其它代码不变,my_reverse函数代码如下。
int my_reverse(int in)
{
return !in;
}