C语言经典算法100道实战题

【C语言经典算法100道实战题】适合具备C语言基础语法的同学学习,提高编写程序的逻辑思维能力和算法设计能力专门精心设计。100个经典的算法供大家练习及配套对应的录播视频。为我们今后学习其它的编程语言和软件开发打下坚实的基础,让你在编码道路上如鱼得水、如虎添翼等,祝同学学习进步、快乐开心的学习编程,感谢大家的全力支持。

各位可爱的同学们好,现在已经为大家准备好超级精典的C语言、C++语言、C语言经典算法100例、数据结构算法(C语言版)、Windows高级编程(上下册)项目实战课程,希望可以帮助大家提高编程实战水平,点击链接就可以学习啦,祝大家学习开心,天天进步、前程似锦!!!

【C语言经典算法100道实战题】点击链接即可在线学习:

C语言经典算法100道实战题--C/C++视频教程-后端开发-CSDN程序员研修院

全套精品学习视频和程序源码代码已更新(第001讲--第100讲),学习目录参考如下:

001、【题目】水仙花数。

水仙花数(Narcissistic number)又被称为阿姆斯特朗数(Armstrong number)。水仙花数是指一个3位数,它的每个位上的数字的3次幂之和等于它本身(例如:1^3 + 5^3+ 3^3 = 153)。

【程序分析】:

使用for循环语言来控制100-999个数,将每个数分解出个位/十位/百位。

【程序源码】:

/*********************************************

运行平台:Windows 10专业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main(int argc, char *argv[])

{

int i, j, k, n;

printf("\n输出100--999所有的水仙花数:\n");

for (n = 100; n <= 999; n++) // 循环每个数字往循环体里面去判断

{

i = n / 100; /*分解出百位*/

j = n / 10 % 10; /*分解出十位*/

k = n % 10; /*分解出个位*/

/* 个位十位百位的立方和等于该数的本身n ,则输出该水仙花数*/

if (n == (i * i * i + j * j * j + k * k * k))

{

printf("%5d", n); // %5d表示以十进制格式输出,宽度为5

}

}

printf("\n");

return 0;

}

【运行效果】:

002、【题目】斐波那契数列。

古典问题:斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”。有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

【程序分析】:

兔子的规律为数列:0、1、1、2、3、5、8、13、21、34、........。

【程序源码】:

/*********************************************

运行平台:Windows 10专业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main(int argc, char *argv[])

{

long f1, f2;

f1 = f2 = 1;

printf("\n输出斐波那契数列20项数据如下:\n");

for (int i = 1; i <= 20; i++)

{

printf("%12ld %12ld", f1, f2);

if (i % 2 == 0) /* 控制输出每行四个数字 */

printf("\n");

f1 = f1 + f2; /* 前两个月加起来赋值给第三个月 */

f2 = f1 + f2; /* 前两个月加起来赋值给第三个月 */

}

printf("\n");

return 0;

}

【运行效果】:

003、【题目】猴子吃桃问题。

猴子吃桃问题:猴子第一天吃了若干个桃子,当即吃了一半,还不解馋,又多吃了一个; 第二天,吃剩下的桃子的一半,还不过瘾,又多吃了一个;以后每天都吃前一天剩下的一半多一个,到第10天想再吃时,只剩下一个桃子了。问第一天共吃了多少个桃子?

【程序分析】:

采取逆向思维的方法,从后往前推断。第10天剩一个,前一天则为d9 = (d10 +1)*2,以此推算前一天。可以采用递归如下:

Day10--------------------------1

Day9-------------------------- 4

Day8------------------------- 10

Day7-------------------------22

Day6-------------------------46

Day5-------------------------94

Day4-------------------------190

Day3-------------------------382

Day2-------------------------766

Day1-------------------------1534

【程序源码】:

/*********************************************

运行平台:Windows 10专业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main(int argc, char *argv[])

{

int day = 9;

int x1, x2; /* x1表示前一天,x2表示后一天 */

x2 = 1; /* 第10天,剩下一个 */

for(;day>=1;day--) /* 从第9天开始递推到第1天 */

{

/* x2表示后一天的 */

x1 = (x2 + 1) * 2;

x2 = x1;

}

printf("\n\n猴子第一天共计摘下:%d个桃子\n\n", x1);

return 0;

}

【运行效果】:

004、【题目】物体自由落地。

一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?

【程序分析】:

根据源程序如下进行详细分析。

【程序源码】:

/*********************************************

运行平台:Windows 10专业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main(int argc, char *argv[])

{

double sn = 100.0, hn = sn / 2;

for (int n = 2; n <= 10; n++)

{

sn = sn + 2 * hn;/*第n次落地时共经过的米数*/

hn = hn / 2; /*第n次反跳高度*/

}

printf("\n球所经过的路程为:%lf米\n", sn);

printf("第10次反弹调度为:%lf米\n\n", hn);

return 0;

}

【运行效果】:

005、【题目】矩阵对角线元素之和。

求一个3*3矩阵对角线元素之和 。

【程序分析】:

使用双重for循环控制输入二维数组,再将a[i]i](a[0]0]、a[1][1]、a[2][2])累加,则进行输出。

【程序源码】:

/*********************************************

运行平台:Windows 10专业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main(int argc, char *argv[])

{

int a[3][3], sum = 0;

printf("\n请输入矩阵元素值(3*3):\n");

for (int i = 0; i < 3; i++)

{

for (int j = 0; j < 3; j++)

{

scanf_s("%d", &a[i][j]);

}

}

printf("\n输出矩阵(3*3)数据如下:\n");

for (int i = 0; i < 3; i++)

{

for (int j = 0; j < 3; j++)

{

printf("%4d", a[i][j]);

}

printf("\n");

}

printf("\n");

// 求对角线之和

for (int i = 0; i < 3; i++)

sum = sum + a[i][i];

printf("\n矩阵对角线(3*3)元素之和为:%d\n\n", sum);

return 0;

}

【运行效果】:

 006、【题目】求素数。

判断101-200之间有多少个素数,并输出所有素数。

【程序分析】:

判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。

【程序源码】:

/*********************************************

运行平台:Windows 10企业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include "stdafx.h"

#include <stdio.h>

#include <math.h>

int _tmain(int argc, _TCHAR* argv[])

{

int m, i, k, h = 0, leap = 1;

printf("\n");

for (m = 101; m <= 200; m++)

{

k = sqrt(double(m + 1));

for (i = 2; i <= k; i++)

if (m%i == 0)

{

leap = 0; break;

}

if (leap) {

printf("%-4d", m); h++;

if (h % 10 == 0)

printf("\n");

}

leap = 1;

}

printf("\n101到200之间共计有: %d个素数\n\n", h);

return 0;

}

【运行效果】:

007、【题目】分解质因数。

将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

【程序分析】:

对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:

(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,

  重复执行第一步。

(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

【程序源码】:

/*********************************************

运行平台:Windows 10企业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main()

{

int n, i;

printf("\nplease input a number:\n");

scanf_s("%d", &n);

printf("%d=", n);

for (i = 2; i <= n; i++)

{

while (n != i)

{

if (n%i == 0)

{

printf("%d*", i);

n = n / i;

}

else

break;

}

}

printf("%d", n);

return 0;

}

【运行效果】:

008、【题目】完数。

一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程找出1000以内的所有完数。

【程序分析】:参考源代码

【程序源码】:

/*********************************************

运行平台:Windows 10企业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main()

{

static int k[10];

int i, j, n, s;

for (j = 2; j < 1000; j++)

{

n = -1;

s = j;

for (i = 1; i < j; i++)

{

if ((j%i) == 0)

{

n++;

s = s - i;

k[n] = i;

}

}

if (s == 0)

{

printf("%5d is a wanshu", j);

for (i = 0; i < n; i++)

printf("%5d,", k[i]);

printf("%5d\n", k[n]);

}

}

return 0;

}

【运行效果】:

009、【题目】最大公约数和最小公倍数。

输入两个正整数m和n,求其最大公约数和最小公倍数。

【程序分析】:

利用辗除法

【程序源码】:

/*********************************************

运行平台:Windows 10企业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main()

{

int a, b, num1, num2, temp;

printf("请输入两个整数:\n");

scanf_s("%d,%d", &num1, &num2);

if (num1 < num2)

{

temp = num1;

num1 = num2;

num2 = temp;

}

a = num1; b = num2;

while (b != 0)/*利用辗除法,直到b为0为止*/

{

temp = a % b;

a = b;

b = temp;

}

printf("最大公约数:%d\n", a);

printf("最小公倍数:%d\n", num1*num2 / a);

return 0;

}

【运行效果】:

010、【题目】三个数由小到大输出。

【程序分析】:

我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。

【程序源码】:

/*********************************************

运行平台:Windows 10企业版

开发工具:Visual Studio 2017

编程语言:C语言

整理作者:Sirius

修改日期:2020年2月8日

**********************************************/

#include <stdio.h>

int main()

{

int x, y, z, t;

printf("请输入三个整数:\n");

scanf_s("%d%d%d", &x, &y, &z);

if (x > y)

{

t = x; x = y; y = t;

} /*交换x,y的值*/

if (x > z)

{

t = z; z = x; x = t;

}/*交换x,z的值*/

if (y > z)

{

t = y; y = z; z = t;

}/*交换z,y的值*/

printf("从小到大输出结果为: %d %d %d\n", x, y, z);

return 0;

}

【运行效果】:

  • 65
    点赞
  • 676
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
以下是一个低功耗蓝牙广播包的代码解析例子,以 Nordic nRF5 SDK 为例: ``` #include <stdbool.h> #include <stdint.h> #include "nrf.h" #include "nordic_common.h" #include "boards.h" #include "nrf_delay.h" #include "nrf_gpio.h" #include "nrf_drv_clock.h" #include "nrf_drv_power.h" #include "nrf_drv_rng.h" #include "nrf_drv_saadc.h" #include "nrfx_wdt.h" #include "app_error.h" #include "app_timer.h" #include "app_util_platform.h" #include "ble_advdata.h" #include "ble_gap.h" #include "ble_nus.h" #include "ble_hci.h" #include "ble_conn_params.h" #include "ble_conn_state.h" #include "ble_db_discovery.h" #include "ble_hci.h" #include "nrf_ble_gatt.h" #include "nrf_ble_qwr.h" #include "nrf_ble_scan.h" #include "nrf_ble_lesc.h" #include "nrf_ble_conn_params.h" #include "nrf_ble_gq.h" #include "nrf_ble_ancs_c.h" #include "nrf_ble_ans_c.h" #include "nrf_ble_bms_c.h" #include "nrf_ble_cscs_c.h" #include "nrf_ble_gattc.h" #include "nrf_ble_ias_c.h" #include "nrf_ble_lbs_c.h" #include "nrf_ble_rscs_c.h" #include "nrf_ble_tps_c.h" #include "nrf_ble_wscs_c.h" #include "bsp_btn_ble.h" #define DEVICE_NAME "LEDBlinker" /**< Name of device. Will be included in the advertising data. */ #define MANUFACTURER_NAME "NordicSemiconductor" /**< Manufacturer. Will be passed to Device Information Service. */ #define APP_BLE_CONN_CFG_TAG 1 /**< A tag identifying the SoftDevice BLE configuration. */ #define APP_ADV_INTERVAL 1600 /**< The advertising interval (in units of 0.625 ms. This value corresponds to 1 sec). */ #define APP_ADV_DURATION 0 /**< The advertising duration (180 seconds) in units of 10 milliseconds. */ #define APP_BLE_OBSERVER_PRIO 3 /**< Application's BLE observer priority. You shouldn't need to modify this value. */ #define APP_BLE_CONN_CFG_TAG 1 /**< A tag identifying the SoftDevice BLE configuration. */ #define APP_FEATURE_NOT_SUPPORTED BLE_GATT_STATUS_ATTERR_APP_BEGIN + 2 /**< Reply when unsupported features are requested. */ static ble_gap_adv_params_t m_adv_params; /**< Parameters to be passed to the stack when starting advertising. */ static uint8_t m_adv_handle = BLE_GAP_ADV_SET_HANDLE_NOT_SET; /**< Advertising handle used to identify an advertising set. */ static uint8_t m_enc_advdata[BLE_GAP_ADV_SET_DATA_SIZE_MAX]; /**< Buffer for storing an encoded advertising set. */ static uint8_t m_enc_scandata[BLE_GAP_ADV_SET_DATA_SIZE_MAX]; /**< Buffer for storing an encoded advertising set. */ static void advertising_start(void) { ret_code_t err_code; err_code = sd_ble_gap_adv_start(m_adv_handle, APP_BLE_CONN_CFG_TAG); APP_ERROR_CHECK(err_code); } static void advertising_init(void) { ret_code_t err_code; ble_advdata_t advdata; ble_advdata_manuf_data_t manuf_data; manuf_data.company_identifier = 0xFFFF; manuf_data.data.p_data = (uint8_t *) "Hello"; manuf_data.data.size = 5; memset(&advdata, 0, sizeof(advdata)); advdata.name_type = BLE_ADVDATA_FULL_NAME; advdata.include_appearance = true; advdata.flags = BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE; advdata.p_manuf_specific_data = &manuf_data; memset(m_enc_advdata, 0, sizeof(m_enc_advdata)); memset(m_enc_scandata, 0, sizeof(m_enc_scandata)); err_code = ble_advdata_encode(&advdata, m_enc_advdata, &m_adv_params.adv_data.len); APP_ERROR_CHECK(err_code); err_code = sd_ble_gap_adv_data_set(m_adv_handle, m_enc_advdata, m_adv_params.adv_data.len, m_enc_scandata, m_adv_params.scan_rsp_data.len); APP_ERROR_CHECK(err_code); } static void gap_params_init(void) { ret_code_t err_code; ble_gap_conn_params_t gap_conn_params; err_code = sd_ble_gap_tx_power_set(BLE_GAP_TX_POWER_ROLE_ADV, m_adv_handle, 4); APP_ERROR_CHECK(err_code); err_code = sd_ble_gap_conn_params_get(&gap_conn_params); APP_ERROR_CHECK(err_code); gap_conn_params.min_conn_interval = MSEC_TO_UNITS(20, UNIT_1_25_MS); gap_conn_params.max_conn_interval = MSEC_TO_UNITS(75, UNIT_1_25_MS); gap_conn_params.slave_latency = 0; gap_conn_params.conn_sup_timeout = MSEC_TO_UNITS(4000, UNIT_10_MS); err_code = sd_ble_gap_conn_params_set(&gap_conn_params); APP_ERROR_CHECK(err_code); } int main(void) { ret_code_t err_code; err_code = nrf_drv_clock_init(); APP_ERROR_CHECK(err_code); nrf_drv_clock_lfclk_request(NULL); err_code = nrf_drv_power_init(NULL); APP_ERROR_CHECK(err_code); err_code = nrf_drv_rng_init(NULL); APP_ERROR_CHECK(err_code); err_code = app_timer_init(); APP_ERROR_CHECK(err_code); err_code = bsp_init(BSP_INIT_LED, NULL); APP_ERROR_CHECK(err_code); err_code = sd_ble_gap_adv_set_configure(&m_adv_handle, &m_enc_advdata[0], &m_adv_params, &m_enc_scandata[0]); APP_ERROR_CHECK(err_code); gap_params_init(); advertising_init(); advertising_start(); while (1) { // Do nothing. } } ``` 该例子使用了 Nordic nRF5 SDK,实现了一个低功耗蓝牙广播包的发送。在 `advertising_init()` 函数中,定义了广播包的参数和内容,使用 `ble_advdata_encode()` 函数将广播包编码成二进制数据,并通过 `sd_ble_gap_adv_data_set()` 函数设置广播包数据。在 `advertising_start()` 函数中,启动了广播传输。 需要注意的是,该例子使用了 Nordic nRF5 SDK,如果您使用其他的嵌入式平台和开发工具,代码会有所不同。但是,低功耗蓝牙广播包的实现原理是相同的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

C++编程指南

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值