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;
}
相关推荐
jz_ddk13 分钟前
[实战]调频(FM)和调幅(AM)信号生成(完整C语言实现)
c语言·算法·信号处理
CloudAce云一29 分钟前
谷歌云代理商:谷歌云TPU/GPU如何加速您的AI模型训练和推理
算法
轻语呢喃1 小时前
每日LeetCode : 杨辉三角
javascript·后端·算法
码农Cloudy.1 小时前
C语言<数据结构-链表>
c语言·数据结构·链表
YuTaoShao2 小时前
【LeetCode 热题 100】148. 排序链表——(解法二)分治
java·算法·leetcode·链表
Shilong Wang2 小时前
三维旋转沿轴分解
算法·计算机视觉·机器人
ygming2 小时前
Q43- code973- 最接近原点的 K 个点 + Q44- code347- 前 K 个高频元素
前端·算法
lightqjx2 小时前
【数据结构】顺序表(sequential list)
c语言·开发语言·数据结构·算法
ygming2 小时前
Hashmap/ Hashset- Q39~Q42内容
前端·算法
蒟蒻小袁3 小时前
力扣面试150题--全排列
算法·leetcode·面试