int fn2(const char *str)
{
const char *p1, *p2;
if (*str == '\0')
return 0;
for (p1 = str; *p1 != ''; p1++)
for (p2 = p1 + 1; *p2 !=''; p2++)
if (*p1 == *p2)
return 1;
return 0;
}
.请参考整型变量i与0值做比较的判断条件(if(i==0)和if(i!=0))的写法写出以下判断
布尔值flag与0
float型与0
char *p 与0
答:
不尔值flag与0
===========================
标准答案: if ( flag ) if ( !flag )
float型与0
===========================
const float EPSINON = 0.000001;if ((x >= - EPSINON) &&
(x <= EPSINON)
str*p 与0
===========================
标准答案: if (p == NULL) if (p != NULL)
另:
1、如何用<<,>>,|,&实现一个WORD(2个字节)的高低位交换?
int test;
test = ( test<<8 & 0xFF00 ) | ( test>>8 &
0x00FF );
2、已知链表头节点元素为head,指向下一节点的成员为head.next;要求不使用临时节点元素写出反序链表的C代码。
答:
void Invert(struct node *p)
{
if(p->next==NULL) return;
if(p->next->next!=0)
Invert(p->next);
p->next->next = p;
p->next = 0;
}
3、如何判断一个数是否是2的幂方?
答: #define Is2n(a) ( a > 0 ) && ( ( ( ~a + 0x01 ) &a
) == a )
4、有一百个整数,其中有负数,找出连续三个数之和最大的部分.
答:
但这种算法跟用最直接的方法来做的效率比并没有多大差异,仅仅提供一种思路。
#include
using namespace std;
void main()
{
int a[10]={-3,4,6,8,-9,7,10,-6,20,-9};
int sum=a[0]+a[1]+a[2];//和
int index=0; //该行的最小下标
int d=0; //递增值
for(int i=3;i<10;++i)
{
d=d+a[i]-a[i-3];
if(d>0)
{
sum = sum + d;
index=i-2;
d=0;
}
}
cout<