網(wǎng)站首頁 編程語言 正文
1.采用冒泡的方式模擬實(shí)現(xiàn)qsort
簡述回調(diào)函數(shù):
回調(diào)函數(shù)就是一個(gè)通過函數(shù)指針調(diào)用的函數(shù)。如果你把函數(shù)的指針(地址)作為參數(shù)傳遞給另一個(gè)函數(shù),當(dāng)這個(gè)指針被用來調(diào)用其所指向的函數(shù)時(shí),我們就說這是回調(diào)函數(shù)。回調(diào)函數(shù)不是由該函數(shù)的實(shí)現(xiàn)方直接調(diào)用,而是在特定的事件或條件發(fā)生時(shí)由另外的一方調(diào)用的,用于對(duì)該事件或條件進(jìn)行響應(yīng)。
模擬實(shí)現(xiàn)qsort函數(shù)源代碼(采用冒泡的方式):
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
void swap(void* p1, void* p2, int n)
{
for (int i = 0; i < n; ++i)
{
char tmp = *((char*)p1 + i);
*((char*)p1 + i) = *((char*)p2 + i);
*((char*)p2 + i) = tmp;
}
}
int cmp(const void* elem1, const void* elem2)
{
return (*((int*)elem1) - *((int*)elem2));
}
void Bubble(void* base, int count, int size, int(*cmp)(void*, void*))
{
int i = 0;
int j = 0;
for (i = 0; i < count - 1; i++)
{
for (j = 0; j < count - i - 1; j++)
{
if (cmp((char*)base + j * size, (char*)base + (j + 1) * size) > 0)
swap((char*)base + j * size, (char*)base + (j + 1) * size, size);
}
}
}
void PrintArray(int ar[], int n)
{
for (int i = 0; i < n; i++)
{
printf("%d ", ar[i]);
}
printf("\n");
}
void main()
{
int ar[10] = { 1,3,4,6,2,7,9,8,22,11 };
int sz = sizeof(ar) / sizeof(ar[0]);
PrintArray(ar, sz);
Bubble(ar, sz, sizeof(ar[0]), cmp);
PrintArray(ar, sz);
}
2.模擬實(shí)現(xiàn)strcpy函數(shù)規(guī)定
- 源字符串必須以 ‘\0’ 結(jié)束。
- 源字符串中的 ‘\0’ 也將會(huì)拷貝到。
- 目標(biāo)空間必須足夠大,以確保能存放源字符串。
- 目標(biāo)空間必須可變。
源代碼:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
char* my_strcpy(char* strDestination, const char* strSource)
{
//要判斷參數(shù)的有效性
assert(strDestination != NULL && strSource != NULL);
//參數(shù)保護(hù)
char* pDest = strDestination;
while (*strSource != '\0')
{
*pDest++ = *strSource++;
}
*pDest = '\0';
return strDestination;
}
void main()
{
char str1[20] = "HelloABC";
char* str2 = "Linux";
printf("str1 = %s\n", str1);
char* res = my_strcpy(str1, str2);
printf("str1 = %s\n", res);
}
3.模擬實(shí)現(xiàn)strcat函數(shù)規(guī)定
- 源字符串必須以 ‘\0’ 結(jié)束。
- 目標(biāo)空間必須有足夠的大,能容納下源字符串的內(nèi)容。
- 目標(biāo)空間必須可修改
源代碼:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
char* my_strcat(char* strDestination, const char* strSource)
{
//要判斷參數(shù)的有效性
assert(strDestination != NULL && strSource != NULL);
//參數(shù)保護(hù)
char* pDest = strDestination;
while (*pDest != '\0')
pDest++;
while (*strSource != '\0')
*pDest++ = *strSource++;
*pDest = '\0';
return strDestination;
}
void main()
{
char str1[20] = "Helloabc";
char* str2 = "Linux";
printf("str1 = %s\n", str1);
char* res = my_strcat(str1, str2);
printf("str1 = %s\n", res);
}
4.模擬實(shí)現(xiàn)strcmp函數(shù)規(guī)定
- 第一個(gè)字符串大于第二個(gè)字符串,則返回大于0的數(shù)字
- 第一個(gè)字符串等于第二個(gè)字符串,則返回0
- 第一個(gè)字符串小于第二個(gè)字符串,則返回小于0的數(shù)字
源代碼:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
int my_strcmp(const char* string1, const char* string2)
{
assert(string1 != NULL && string2 != NULL);
int res = 0;
while (*string1 != '\0' || *string2 != '\0')
{
//通過減法的方式完成比較
if ((res = *string1 - *string2) != 0)
break;
string1++;
string2++;
}
if (res > 0)
res = 1;
else if (res < 0)
res = -1;
return res;
}
void main()
{
char* str1 = "Helloab";
char* str2 = "HelloABCab";
int res = my_strcmp(str1, str2);
printf("res = %d\n", res);
}
原文鏈接:https://blog.csdn.net/Onion_521257/article/details/105498713
相關(guān)推薦
- 2023-08-13 fastadmin框架怎么重定向至后臺(tái)模塊
- 2022-03-19 c語言執(zhí)行Hello?World背后經(jīng)歷的步驟_C 語言
- 2022-06-15 GO語言字符串處理Strings包的函數(shù)使用示例講解_Golang
- 2022-09-26 Python調(diào)整matplotlib圖片大小的3種方法匯總_python
- 2022-04-17 python數(shù)據(jù)庫操作之sqlalchemy逆向工程
- 2022-04-28 C++?多線程之互斥量(mutex)詳解_C 語言
- 2022-04-11 Docker部署SonarQube的詳細(xì)流程_docker
- 2022-05-03 C#面向?qū)ο笤O(shè)計(jì)原則之單一職責(zé)原則_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支