不可以!
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
判断:两个数x、y的正负性。
要求:不可以使用比较运算符,即"<",">","<=",">=","==","!="。
-
输入
-
有多组数据,每组数据占一行,每一行两个数x,y。
x、y保证在int范围内。
输出
-
每组数据输出占一行。
如果两个数是一正一负,输出"Signs are opposite"
如果是同为正或同为负,输出"Signs are not opposot"
如果无法确定,输出"Signs can't be sure"
输出不包括引号
样例输入
-
1 1 -1 1
样例输出
-
Signs are not opposot Signs are opposite
提示
- 如对本题有何疑问,请到讨论区提问或邮件我! 来源
- 爱生活 上传者
-
TCM_张鹏
我的程序:
#include<stdio.h> int main() { int a,b; while(scanf("%d%d",&a,&b)!=EOF){ if(!(a*b)){ //讨论a,b有一个数为0,符号不存在的情况 printf("Signs can't be sure\n"); continue; } if((a>>31)^(b>>31)) printf("Signs are opposite\n"); else printf("Signs are not opposot\n"); } return 0; }
最优程序:01.
#include<stdio.h>
02.
int
main()
03.
{
04.
int
a,b,c;
05.
while
(~
scanf
(
"%d%d"
,&a,&b))
06.
{
07.
c=((a>>31)&1)+((b>>31)&1);
08.
if
((!a)||(!b))
printf
(
"Signs can't be sure\n"
);
09.
else
printf
(
"Signs are %s\n"
,c&1?
"opposite"
:
"not opposot"
);
10.
}
11.
}
-
有多组数据,每组数据占一行,每一行两个数x,y。