C语言练习(检查一个数是否为质数 、剪绳子)

2023-12-16 08:28

本文主要是介绍C语言练习(检查一个数是否为质数 、剪绳子),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

检查一个数是否为质数 

题目描述

输入格式

输出格式

样例输入

样例输出

解题思路

代码示例

剪绳子

题目描述

输入格式

输出格式

样例输入

样例输出

解题思路

代码示例


检查一个数是否为质数 

题目描述

输入一个正整数,检查该数是否为质数

输入格式

输入一个正整数

输出格式

输出Y或者N

样例输入

34

样例输出

N

解题思路

首先,先了解什么是质数?

所谓质数(素数)就是一个大于1的自然数,除了本身和1外,不能被其他自然数整除的数。

对此,我们输入n,那么我们可以用i=2~n-1的自然数来逐个求余数;

那么就要用for循环语句实现i从2变化到n-1的功能,直到i=n或n%i==0退出循环。

代码示例

//Dev C++代码
#include<stdio.h>main(){int i, n, s;char ch, cm;ch = 'N'; cm = 'Y';scanf("%d", &n);for (i = 2; i < n; i++){s = n % i;if (s == 0)break;}if (s == 0)printf("%c", ch);else printf("%c", cm);}

对此,若是在Dev C++中编译,正常

但是,如果在Visual Studio中编译则会出现报错:

C4996	'scanf': This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.	Project16	D:\Visual Studio\project\Project16\Project16\FileName.cpp	9	

解决方法,将sancf改为scanf_s

更多解决方法可以参考:

Visual Studio编辑器中C4996 ‘scanf‘: This function or variable may be unsafe.问题解决方案-CSDN博客

这样还会出现一个问题,主函数,也会报错,因为缺少类型说明符,可以再main()改为void main()

更改后的代码如下:

//Visual Studio代码
#include<stdio.h>void main(){int i, n, s;char ch, cm;ch = 'N'; cm = 'Y';scanf_s("%d", &n);for (i = 2; i < n; i++){s = n % i;if (s == 0)break;}if (s == 0)printf("%c", ch);else printf("%c", cm);}

由于编译环境不同,根据个人需求,自行选择。


剪绳子

题目描述

给一段N cm长的绳子,每次剪成相等的两段。求最少经过多少次,其长度小于1cm?

输入格式

输入有多组数据,每组一个正整数N,表示绳子长度为N cm(1<n<=100000)。

输出格式

最少的次数。

样例输入

2
3

样例输出

2
2

解题思路

递归算法的思路是:

递归算法最重要的是需要结束条件: N<1时 结束。

其他情况 返回 fun(N/2)

递归算法:

        程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。一般来说,递归需要有边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。

递归,就是在运行的过程中调用自己。

构成递归需具备的条件:

函数嵌套调用过程示例

1. 子问题须与原始问题为同样的事,且更为简单;

2. 不能无限制地调用本身,须有个出口,化简为非递归状况处理。

        在数学和计算机科学中,递归指由一种(或多种)简单的基本情况定义的一类对象或方法,并规定其他所有情况都能被还原为其基本情况。

注意事项:

注意g_count计数器每次要清空!

代码示例

//Visual Studio代码
#include <stdio.h>
int g_count = 0;
int fun(int N)
{if (N < 1)return 0;elseg_count++;return fun(N / 2);
}
int main()
{int N;while (~scanf_s("%d", &N)){fun(N);printf("%d\n", g_count);g_count = 0;}
}
//Dev C++代码
#include <stdio.h>
int g_count = 0;
int fun(int N)
{if (N < 1)return 0;elseg_count++;return fun(N / 2);
}
int main()
{int N;while (~scanf("%d", &N)){fun(N);printf("%d\n", g_count);g_count = 0;}
}

由于编译环境不同,根据个人需求,自行选择。

更多scanf报错解决方案:

Visual Studio编辑器中C4996 ‘scanf‘: This function or variable may be unsafe.问题解决方案-CSDN博客

这篇关于C语言练习(检查一个数是否为质数 、剪绳子)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/499832

相关文章

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推