04【C语言 & 趣味算法】“抓交通肇事犯”问题。算法改进:设置“标识变量”,有效减少循环次数。

简介: 04【C语言 & 趣味算法】“抓交通肇事犯”问题。算法改进:设置“标识变量”,有效减少循环次数。

一、指路指路



03【C语言&趣味算法】(值得品味的一道题)打鱼还是晒网?结构体的简单应用。函数的应用。判断闰年的应用。求指定日期距1990年1月1日的天数。

02【C语言&趣味算法】借书方案问题:小明有5本新书,要借给A、B、C三位小朋友,若每人每次只能借1本,则可以有多少种不同的借法?

01【C语言&趣味算法】百钱百鸡问题(问题简单,非初学者请忽略叭)。请注意算法的设计(程序的框架),程序流程图的绘制,算法的优化。


二、Problem:抓交通肇事犯



这是很有意思的一道"数学题”。有趣的地方,在于后面对于Algorithm的优化与改进。


2.1问题描述

2e822a23998d4ff4b8349cf7226cb7e1.jpg


2.2 problem分析


要注意“取值范围”。

1c1febf038f1412b9ad3973bf1a8f527.jpg


2.3算法设计

d89b084ff8fb4561bbe100fcf38e8e18.jpg


2.4确定程序框架:程序流程图的绘制

97a58e581d0d47a6a8bafb91693ef4b9.jpg09ddd72a12004baeb3dc7ace37680c8d.jpg


2.5判断车牌k是否为某个数的平方

f09f3627808f4ba0b82b0debf1ec7436.jpg


2.6完整code及输出


// 趣味04:抓交通肇事犯 问题 
#include<stdio.h>
int main()
{
 int i,j,k,temp;        /*i代表前两位车牌号数字,j代表后两位车牌号的数字,k代表车牌号*/
 for(i=0;i<=9;i++)
  for(j=0;j<=9;j++)   /*穷举前两位和后两位车牌数字*/
  {
    /*判断前两位数字和后两位数字是否不同*/
    if(i!=j)
    {
      /*组成4位车牌号k*/
      k=1000*i+100*i+10*j+j;
      /*判断k是否是某个数的平方,若是则输出k*/
      for(temp=31;temp<=99;temp++)
        if(temp*temp==k)
          printf("车牌号为%d",k);
    }
  }
}

输出如下:


4eb5ae0768874500abd8c79a9d859821.jpg


2.7优化,改进Algorithm

d6ae0496c01642c58e4c6145a667c40e.jpg


相关文章
|
2天前
|
搜索推荐 算法 C语言
【排序算法】八大排序(上)(c语言实现)(附源码)
本文介绍了四种常见的排序算法:冒泡排序、选择排序、插入排序和希尔排序。通过具体的代码实现和测试数据,详细解释了每种算法的工作原理和性能特点。冒泡排序通过不断交换相邻元素来排序,选择排序通过选择最小元素进行交换,插入排序通过逐步插入元素到已排序部分,而希尔排序则是插入排序的改进版,通过预排序使数据更接近有序,从而提高效率。文章最后总结了这四种算法的空间和时间复杂度,以及它们的稳定性。
26 8
|
2天前
|
搜索推荐 算法 C语言
【排序算法】八大排序(下)(c语言实现)(附源码)
本文继续学习并实现了八大排序算法中的后四种:堆排序、快速排序、归并排序和计数排序。详细介绍了每种排序算法的原理、步骤和代码实现,并通过测试数据展示了它们的性能表现。堆排序利用堆的特性进行排序,快速排序通过递归和多种划分方法实现高效排序,归并排序通过分治法将问题分解后再合并,计数排序则通过统计每个元素的出现次数实现非比较排序。最后,文章还对比了这些排序算法在处理一百万个整形数据时的运行时间,帮助读者了解不同算法的优劣。
20 7
|
19天前
|
C语言
【c语言】循环语句
循环结构是C语言中用于简化重复操作的重要工具,主要包括while循环、do-while循环和for循环。while循环是最基本的形式,通过不断检查条件来决定是否继续执行循环体。do-while循环则先执行循环体,再检查条件,至少执行一次。for循环逻辑更复杂,但使用频率最高,适合初始化、条件判断和更新变量的集中管理。此外,循环中还可以使用break和continue语句来控制循环的提前终止或跳过当前迭代。最后,循环可以嵌套使用,解决更复杂的问题,如查找特定范围内的素数。
30 6
|
20天前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
33 1
|
23天前
|
存储 C语言
C语言指针与指针变量的区别指针
指针是C语言中的重要概念,用于存储内存地址。指针变量是一种特殊的变量,用于存放其他变量的内存地址,通过指针可以间接访问和修改该变量的值。指针与指针变量的主要区别在于:指针是一个泛指的概念,而指针变量是具体的实现形式。
|
1月前
|
存储 C语言
C语言:设置地址为 0x67a9 的整型变量的值为 0xaa66
在C语言中,可以通过指针操作来实现对特定地址的访问和赋值。要将地址为 0x67a9 的整型变量值设为 0xaa66,可以先定义一个指向该地址的指针,并通过该指针对该内存位置进行赋值操作。需要注意的是,直接操作内存地址具有一定风险,必须确保地址合法且可写。代码示例应考虑字节序及内存对齐问题。
|
29天前
|
C语言
教你快速理解学习C语言的循环与分支
教你快速理解学习C语言的循环与分支
15 0
|
30天前
|
小程序 C语言
初识C语言:走近循环
初识C语言:走近循环
|
30天前
|
存储 C语言
初识C语言:常量与变量中寻找数据类型
初识C语言:常量与变量中寻找数据类型
|
28天前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
31 3
下一篇
无影云桌面