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;
}
相关推荐
承渊政道13 小时前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
WL_Aurora13 小时前
Python 算法基础篇之排序算法(二):希尔、快速、归并
python·算法·排序算法
闻缺陷则喜何志丹13 小时前
【图论 树 启发式合并】P7165 [COCI2020-2021#1] Papričice|普及+
c++·算法·启发式算法·图论··洛谷
alexwang21113 小时前
AT_abc458_d [ABC458D] Chalkboard Median题解
c++·算法·题解·atcoder
故事和你9113 小时前
洛谷-【图论2-4】连通性问题1
开发语言·数据结构·c++·算法·动态规划·图论
周末也要写八哥14 小时前
算法实例分析:使数组相等的最小开销
算法
吃好睡好便好14 小时前
在Matlab中绘制质点运动轨迹图
开发语言·学习·算法·matlab·信息可视化
爱炼丹的James14 小时前
第三章 搜索和图论
数据结构·算法·图论
菜菜笔记14 小时前
【无标题】
算法
努力努力再努力wz14 小时前
【QT入门系列】QWidget 六大常用属性详解:windowOpacity、cursor、font、focus、toolTip 与 styleSheet
android·开发语言·数据结构·c++·qt·mysql·算法