刷题-程序员面试宝典

最近快面临找工作了,开始每天的刷题之旅

知识点1:关于与或非赋值操作

int x=2,y,z
x*=(y=z=5);//x=2*5=10
x=(y&z);//x=5 y的二进制是101 z的二进制是101
x=(y&&z);//x=1;两个&&表示布尔
同理可知(y|z)与(y||z)的区别

知识点2:统计1的个数

//这个函数返回的时候,形参X转化成二进制后包含1的个数
int func(int x)
{
    int countx = 0;
    while(x)
    {
        countx++;
        x = x&(x-1);
    }
    return countx;
} 
int main()
{
std::cout<

知识点3:for循环

int a,x;
//版本1
for (a=0,x=0;a<=1&&!x++;a++)
{
a++;
}
//程序在运行时的步骤
1、初始化定义a=0,x=0(确定判断的终止条件:a>1或者x=1)
2、进行for循环的前两个语句,此时a=0,x=1
3、进行循环体中此时a=1,x=1
4、进行for循环的第三个语句,此时a=2
5、进入for循环第2个语句,判断终止条件,由于a>1,判断终止,不进入!x++语句,因此
最终输出结果a=2,x=1
在for循环中,如为1则,进入循环判断。不为1则跳出循环判断

知识点4:判断一个数是否是2的N次方

int func(int x)
{
    if( (x&(x-1)) == 0 )//利用X&(X-1)来判断
        return 1;
    else
        return 0;
}

知识点5:一半一半

int f(int x, int y)
{
    return (x&y)+((x^y)>>1)
}
//其中(x&y)+((x^y)>>1)  相当于(x+y)/2

知识点6:时间复杂度和空间复杂度

时间复杂度是-》大概程序需要执行的次数(而非执行时间)

空间复杂度是-》大概程序所占用的最大内存

地址是:内存单元的编号  指针就是地址,地址就是指针

指针变量,是存放内存单元地址的变量。

结构体和类的区别,结构体没有方法

struct Student
{
    int sid;
    char name[200];
    int age;
}
 
int main()
{
    struct Student st={1000,"zhangsan",20};
    st.sid=6;
    struct Student *pst;
//   也可以考虑整体的的赋值 psd=&st;
    pst->sid=99;
}

如果我的返回数据是一个数组的话,那么我定义的数据类型应该是一个指针类型。

知识点7  返回一个在0-50之间的随机数

#include 
#include 
#include 
using namespace std;
namespace SortTestHelper
{
	//由于我需要返回的是一个数组
  int * generateRandomArray(int n,int rangeL,int rangeR){
	  assert(rangeL<=rangeR);//做一个判定
       int *arr=new int[n];
	   srand(time(NULL));//随机种子的测试
	  for(int i=0;i

知识点8:选择排序

选择排序就是对数组中所有的元素,首先找到最小的元素,然后把它放在第一个位置,然后再找这个数组中剩下元素中最小的元素,把他放在第二个位置上面,依次类推。

 

//版本1	
void selectSort(int arr[],int n)
	{
		//对数组进行遍历
	 for(int i=0;i
	void selectSort(T arr[],int n)
	{
		//对数组进行遍历
	 for(int i=0;i

知识点9 测算函数的复杂度

#include 
#include 
#include 
#include 
template
	void selectSort(T arr[],int n)
	{
		//对数组进行遍历
	 for(int i=0;i//必须写两个template,每个模板对应一个
void testSort(string sortName,void(*sort)(T[] ,int),T arr[],int n)
{
    clock_t startTime=clock();
	sort(arr,n);
	clock_t endTime=clock();
	cout<

知识点10:插入排序

对前面的元素进行排查,然后比较该元素和该元素的前一个元素

template
void insertSort(T arr[],int n)
{
	for(int i=0;i0;j--)//对i前面的元素进行排查
	   {
	     if(arr[j]<=arr[j-1])
		 {
			 swap(arr[j],arr[j-1]);	
		 }
         else
           break;
	   }
	}
    return ;
}

在这里由于使用到了swap函数,使得算法的效率不高,因此不适用这个函数

template
void insertSort(T arr[],int n)
{
	for(int i=0;i0;j--)//对i前面的元素进行排查
	   {
	     if(arr[j-1]>e)
		 {
			arr[j]=arr[j-1]
		 }
         else
           break;
	   }
      arr[j]=e;
	}
    return ;
}

 

知识点11 拷贝一个数组

int* 的东西就是这个数组头指针

int * CopyArry(int a[],int n)
{
int arr =new int[n];
copy(a,a+n,arr);//第一个参数是头指针,第二个是尾指针,最后一个目标的头指针
return arr;
}

知识点12 冒泡排序的

 

知识点13 希尔排序

 

知识点14 归并排序

 

知识点15 快速排序

 

 

 

 

 

你可能感兴趣的:(【C++编程】)