C语言(2)--牛顿迭代法、舍罕王的赏赐、解两个不等式、枚举类型变量输出三原色全排列

本文主要是介绍C语言(2)--牛顿迭代法、舍罕王的赏赐、解两个不等式、枚举类型变量输出三原色全排列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.牛顿迭代法求方程近似解

原理:对于方程f(x)=0,令xk+1=xk-f(xk)/f '(xk)k=0,1,···

当修正量dk=f(xk)/f '(xk)的绝对值小于某个很小的数ε时,xk+1就作为方程的近似解。

例:用牛顿迭代法求方程2*x*x*x-4*x*x+3*x-6=0在1.5附近的根,要求误差小于1E-6.

代码:

#include <stdio.h>
#include <math.h>
#define epsilon 1.0e-6
int main()
{float x=1.5,d;do{d=(((2*x-4)*x+3)*x-6)/((6*x-8)*x+3);x=x-d;}while(fabs(d)>epsilon);printf("方程的根=%6.2f\n",x);return 0;
}
运行:


2.统计字符

输入一个长度小于100的字符串,统计该字符串中大写字母、小写字母、数字字符和其他字符的数量。

#include <stdio.h>
#define N 100
int main()
{char str[N];int i,big=0,sma=0,num=0,oth=0;gets(str);for(i=0;str[i];i++)if('A'<=str[i]&&str[i]<='Z')	big++;                   //大写字母 else{if('a'<=str[i]&&str[i]<='z')	sma++;           //小写字母 else{if('0'<=str[i]&&str[i]<='9')	num++;   //数字字符 else	oth++;                           //其他字符}}printf("大写字母有%d个\n",big);printf("小写字母有%d个\n",sma);printf("数字字符有%d个\n",num);printf("其他字符有%d个\n",oth);return 0;
}
3.舍罕王的赏赐

传说,古印度时舍罕王打算重赏发明国际象棋的宰相西塞班达伊尔,于是问他想要什么赏赐。宰相说,我想要一些麦子,在8*8的象棋盘上,第一格放一粒,第二格2粒,第三格4粒,第四格8粒,......,依此类推,每一格的数量是前一格的两倍,放满64格,把这些麦子都赏给我就足够了。
问:一共需要多少粒麦子?合计多少立方米(1立方米麦子约1.42e8粒)?如果堆成正圆锥形的麦堆,麦堆约多高?

代码:

#include <stdio.h>
#include <math.h>
#define M 64
#define PI 3.1415926
int main()
{double i,t=1,sum=1;double v,h;for(i=1;i<M;i++){t*=2;sum+=t;}v=(double)sum/(1.42e8);h=pow(9*v/PI,1.0/3);printf("共有%.3e粒麦子\n",sum);printf("合计%4.2f立方米\n",v);printf("可以堆成约%5.2f米高的正圆锥形麦堆\n",h);return 0;
}
运行;


4.解两个不等式

题目来源于《趣味C程序设计》



代码:

<span style="font-size:18px;">#include <stdio.h>
int main()
{int i=1,j=1;double sum1=0,sum2=0;while(1)	{sum1+=1.0/i;if(sum1>10)		{printf("不等式①的解为:%d<=m",i);break;}i++;}sum1=0,i=1;while(1)	{sum1+=1.0/i;if(sum1>11)		{printf("<=%d\n",i-1);break;}i++;}while(1){if(j%3==0)	sum2+=(-(1.0/j));else		sum2+=1.0/j;if(sum2>4)	{break;}j++;	}if(sum2-1.0/(j+1)>4) printf("不等式②的解为:%d<=m\n",j);else{if(sum2-1.0/(j+1)+1.0/(j+2)>4)	printf("不等式②的解为:%d和%d<=m\n",j,j+2);	else		printf("不等式②的解为:%d和%d<=m\n",j,j+3);	}return 0;
}</span>
运行:


5.枚举类型变量输出三原色全排列

定义一个描述三原色(红色、绿色、黄色)的枚举类型,然后通过该枚举类型变量输出这三种颜色的全排列结果

代码:

#include <stdio.h>  
enum color{red,green,yellow};  
int main()  
{  enum color c1,c2,c3;  for(c1=red;c1<=yellow;c1=(enum color)((int)(c1)+1))              /*通过三重循环穷举出所有组合*/   for(c2=red;c2<=yellow;c2=(enum color)((int)(c2)+1))      /*先将c2转换成整型,加1,再转成color型赋值给c2完成c2自加操作*/   for(c3=red;c3<=yellow;c3=(enum color)((int)(c3)+1))    {     show(c1);  show(c2);  show(c3);  printf("\n");      /*每次循环后换行*/   }  printf("\n");  return 0;  
}   
int show(enum color c)     /*show函数输出何种颜色*/   
{  switch(c)  {  case red:   printf("red ");break;  case green: printf("green ");break;  case yellow:printf("yellow ");break;  };  return 0;  
}  
运行:


这篇关于C语言(2)--牛顿迭代法、舍罕王的赏赐、解两个不等式、枚举类型变量输出三原色全排列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时