Chinaunix首页 | 论坛 | 博客
  • 博客访问: 300181
  • 博文数量: 148
  • 博客积分: 4365
  • 博客等级: 上校
  • 技术积分: 1566
  • 用 户 组: 普通用户
  • 注册时间: 2008-07-05 21:38
文章分类
文章存档

2014年(2)

2013年(45)

2012年(18)

2011年(1)

2009年(54)

2008年(28)

我的朋友

分类: C/C++

2009-09-25 23:12:04

写一个函数fn(),功能是传一个参数是字符串,查找里面有没有相同的字符,有的话返回1,否则0.
两种方法,一是效率最高的,二是最节省内存的.
答:
int fn1(const char *str)
{
 unsigned char *p = ( unsigned char *)str;
 int a[255]={0};
 for( ; *p != '\0'; p++ )
  if( ++a[*p] == 2 ) return 1;
 return 0;
}


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;
}

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<

}
阅读(589) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~