2024.2.6

1、

cs 复制代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
//冒泡排序
void Bubble_sort(int arr[],int len)
{
	for(int i=1;i<len;i++)
	{
		for(int j=0;j<len-i;j++)
		{
			if(arr[j]>arr[j+1])
			{
				int t=arr[j];
				arr[j]=arr[j+1];
				arr[j+1]=t;
			}
		}
	}
}
//简单选择排序
void easy_sort(int arr[],int len)
{
	
	for(int i=0;i<len-1;i++)
	{
		int min=i;
		for(int j=i+1;j<len;j++)
		{
			if(arr[min]>arr[j])
			{
				min=j;
			}
			if(min!=i)
			{
				int t=arr[i];
				arr[i]=arr[min];
				arr[min]=t;
			}

		}
	}
}
//插入排序
void insert_sort(int arr[],int len)
{
	int j;
	int temp;
	for(int i=1;i<len;i++)
	{
		temp=arr[i];
		for(j=i-1;j>=0&&arr[j]>temp;j--)
		{
			arr[j+1]=arr[j];
		}
		arr[j+1]=temp;
	}
}
//一次排序
int one_sort(int arr[],int low,int high)
{
	int key=arr[low];
	while(low<high)
	{
		while(low<high&&key<arr[high])
			high--;
		arr[high]=arr[low];
		while(low<high&&key>arr[low])
			low++;
		arr[low]=arr[high];
	}
	arr[low]=key;
	return low;

}
void quick_sort(int arr[],int low,int high)
{
	if(low>high)
		return;
	//一次排序
	int mid=one_sort(arr,low,high);
	//左边序列递归
	quick_sort(arr,low,mid-1);
	//右边序列递归
	quick_sort(arr,mid+1,high);
		
}
void output(int arr[],int len)
{
	for(int i=0;i<len;i++)
	{
		printf("%-5d",arr[i]);
	}
	puts("");
}
int main(int argc, const char *argv[])
{
	int arr[]={23,24,12,5,34,7};
	int len=sizeof(arr)/sizeof(arr[0]);
	//冒泡排序
	Bubble_sort(arr,len);
	output(arr,len);
	//简单选择排序
	easy_sort(arr,len);
	output(arr,len);
	//插入排序
	insert_sort(arr,len);
	output(arr,len);
	//快速排序
	quick_sort(arr,0,len-1);
	output(arr,len);
	
	return 0;
}

2、

cs 复制代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int DigitSum(int n)
{
	if(n==0)
		return 0;
	else
		return n%10+DigitSum(n/10);
}
int main(int argc, const char *argv[])
{
	int n;
	printf("please enter the n:");
	scanf("%d",&n);
	int sum=DigitSum(n);
	printf("sum=%d\n",sum);
	return 0;
}

3、

cs 复制代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define swap(num) (((num&0xaaaaaaaa)>>1)+((num&0x55555555)<<1))
int main(int argc, const char *argv[])
{
	int num;
	printf("please enter the num:");
	scanf("%d",&num);
	printf("the change num is %d\n",swap(num));
	return 0;
}
相关推荐
不穿格子的程序员12 分钟前
从零开始学算法——链表篇3:合并两个有序链表 + 两数相加
数据结构·算法·链表·dummy
暴风鱼划水31 分钟前
算法题(Python)哈希表 | 2.两个数组的交集
python·算法·哈希表
子一!!34 分钟前
数据结构==LRU Cache ==
数据结构
fufu031136 分钟前
Linux环境下的C语言编程(四十二)
linux·c语言·算法
HalvmånEver39 分钟前
Linux : 基础IO(三)
linux·运维·算法
oushaojun241 分钟前
linux中backtrace实战
linux·运维·算法·backtrace
埃伊蟹黄面1 小时前
模拟算法思想
c++·算法·leetcode
副露のmagic1 小时前
更弱智的算法学习day 10
python·学习·算法
hweiyu001 小时前
数据结构:邻接矩阵
数据结构
逸风尊者1 小时前
开发可掌握的知识:uber H3网格
后端·算法