码迷,mamicode.com
首页 > 其他好文 > 详细

求单独出现的数,strncpy的优化

时间:2016-05-18 19:57:55      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:

求未配对的数(1)

在一组数据中有 只有一个数出现了一次,其余的数都是成对的出现,请找出这个数:这个题很容易解决,只要把这组数据全部异或(相同为零,不同为1),所以出现两次的数异或后就为零,最后剩下的就是出现一次的数。

#include<stdio.h>
#include<stdlib.h>

int find_once_num(int arr[], int len )
{
  int num = 0;
   for (int i = 0; i < len; i++)
  {
     num ^= arr[i];
  }
   return num;
}
int main()
{
   int arr[9] = { 8, 4, 2, 7, 9, 8, 4, 2, 7 };
   int ret=find_once_num(arr,9);
   printf( "%d\n",ret);
   system( "pause");
   return 0;
}



(2)

现在将题目变一下,一组数据中只有两个数出现了一次,其余数字都是成对出现的,请找出这两个数,这时就不能直接异或了,必须将这一组数据分成两块,每块只包含一个单独出现的数,这样剩下的问题就和第一题一样了,可关键是怎么分呢???

分析:我们可以先对这组数据进行排序,这样成对出现的数就相邻在一起了,我们再一对一对的比较,直到找到第一对不相等的数,然后从中分开,这样就分成两块了

void bubble_sort(int arr[], int n )
{
   int flag = 0;
   int i = 0;
   int j = 0;
   for (i = 0; i < n - 1; i++)
   {
      flag = 1;
      for (j = 0; j < n - i - 1; j++)          //冒泡排序
      {
        if (arr [j]>arr[j + 1])
        {
          arr[j] = arr [j] + arr[j + 1];
          arr[j + 1] = arr [j] - arr[j + 1];
          arr[j] = arr [j] - arr[j + 1];
          flag = 0;
        }
       }
      if (flag == 1)
        break;
    }
}
int find_one_num(const int *p1,int len)
{
   assert(p1 );
   int num = 0;
    for (int i = 0; i <=len; i++)
   {
    num ^= p1[i];
   }
   return num;
}
int main()
{
  int arr[10] = {0 ,1, 13, 18, 18,13,1,46,0,3};
  int i = 0;
  int *p = arr;
  bubble_sort(arr, 10);
  for (i = 0; i < 10 - 1;)
  {
    if (p[i] == p[i + 1])
    {
      i += 2;
    }
    else
      break;
  }
  printf( "%d   %d \n", find(p, i),find((p+i+1),9-i-1));
  system( "pause");
  return 0;
}





strncpy的优化:

当n很大很大时,如果一个字节一个字节的copy效率会非常低下,所以我们要想一个办法,当n特别大时,使得一次性可以copy多个字节。其实这个办法就是强制类型转换,将char *转换为int *(在c中试了一下转换为double*,显示无法转换),这样一次就可以copy 4个字节,而当n小于4时再转换为char*进行copy.


#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char* my_strncpy(char *dst, const char *src, int len)
{
	assert(dst);
	assert(src);
	int* p1= (int *)dst;
	const int* p2 = (int *)src;
	while (len)
	{
		if (len < 4)
		{
			(char *)*p1=(char *)*p2;
			((char* )p1)++;
			((char *)p2)++;
			len--;
		}
		else
		{
			*p1++ = *p2++;
			len -= 4;
		}

	}
	(char *)*p1 = ‘\0‘;
	return  dst;
}
int main()
{
	char arr1[100];
	char arr2[50];
	int n = 0;
	scanf("%s%s%d", arr1, arr2,&n);
	char *ret = my_strncpy(arr1, arr2, n);
	printf("%s\n",ret);
	system("pause");
	return 0;
}

求单独出现的数,strncpy的优化

标签:

原文地址:http://blog.csdn.net/lf_2016/article/details/51388603

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!