C语言的10大基础算法

640?wx_fmt=gif

算法是一个程序和软件的灵魂,作为一名优秀的程序员,只有对一些基础的算法有着全面的掌握,才会在设计程序和编写代码的过程中显得得心应手。本文是近百个C语言算法系列的第二篇,包括了经典的Fibonacci数列、简易计算器、回文检查、质数检查等算法。也许他们能在你的毕业设计或者面试中派上用场。

1、计算Fibonacci数列

Fibonacci数列又称斐波那契数列,又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21。

C语言实现的代码如下:

/* Displaying Fibonacci sequence up to nth term where n is entered by user. */	
#include <stdio.h>	
int main()	
{	
int count, n, t1=0, t2=1, display=0;	
printf("Enter number of terms: ");	
scanf("%d",&n);	
printf("Fibonacci Series: %d+%d+", t1, t2); /* Displaying first two terms */	
count=2; /* count=2 because first two terms are already displayed. */	
while (count<n) 	
{	
display=t1+t2;	
t1=t2;	
t2=display;	
++count;	
printf("%d+",display);	
}	
return 0;	
}

结果输出:

Enter number of terms: 10	
Fibonacci Series: 0+1+1+2+3+5+8+13+21+34+

也可以使用下面的源代码:

/* Displaying Fibonacci series up to certain number entered by user. */	#include <stdio.h>	
int main()	
{	
int t1=0, t2=1, display=0, num;	
printf("Enter an integer: ");	
scanf("%d",&num);	
printf("Fibonacci Series: %d+%d+", t1, t2); /* Displaying first two terms */	
display=t1+t2;	
while(display<num)	
{	
printf("%d+",display);	
t1=t2;	
t2=display;	
display=t1+t2;	
}	
return 0;	
}

结果输出:

Enter an integer: 200

2、回文检查

 源代码:

/* C program to check whether a number is palindrome or not */	#include <stdio.h>	
int main()	
{	
int n, reverse=0, rem,temp;	
printf("Enter an integer: ");	
scanf("%d", &n);	
temp=n;	
while(temp!=0)	
{	
rem=temp%10;	
reverse=reverse*10+rem;	
temp/=10;	
} 	
/* Checking if number entered by user and it's reverse number is equal. */	
if(reverse==n) 	
printf("%d is a palindrome.",n);	
else	
printf("%d is not a palindrome.",n);	
return 0;	
}

结果输出:

Enter an integer: 12321

3、质数检查

注:1既不是质数也不是合数。

源代码:

/* C program to check whether a number is prime or not. */	#include <stdio.h>	
int main()	
{	
int n, i, flag=0;	
printf("Enter a positive integer: ");	
scanf("%d",&n);	
for(i=2;i<=n/2;++i)	
{	
if(n%i==0)	
{	
flag=1;	
break;	
}	
}	
if (flag==0)	
printf("%d is a prime number.",n);	
else	
printf("%d is not a prime number.",n);	
return 0;	
}

结果输出:

Enter a positive integer: 29

4、打印金字塔和三角形

 使用 * 建立三角形

*

源代码:

#include <stdio.h>	
int main()	
{	
int i,j,rows;	
printf("Enter the number of rows: ");	
scanf("%d",&rows);	
for(i=1;i<=rows;++i)	
{	
for(j=1;j<=i;++j)	
{	
printf("* ");	
}	
printf("\n");	
}	
return 0;	
}

如下图所示使用数字打印半金字塔。

1

源代码:

#include <stdio.h>	
int main()	
{	
int i,j,rows;	
printf("Enter the number of rows: ");	
scanf("%d",&rows);	
for(i=1;i<=rows;++i)	
{	
for(j=1;j<=i;++j)	
{	
printf("%d ",j);	
}	
printf("\n");	
}	
return 0;	
}

用 * 打印半金字塔

* * * * *

源代码:

#include <stdio.h>	
int main()	
{	
int i,j,rows;	
printf("Enter the number of rows: ");	
scanf("%d",&rows);	
for(i=rows;i>=1;--i)	
{	
for(j=1;j<=i;++j)	
{	
printf("* ");	
}	
printf("\n");	
}	
return 0;	
}

用 * 打印金字塔

*

源代码:

#include <stdio.h>	
int main()	
{	
int i,space,rows,k=0;	
printf("Enter the number of rows: ");	
scanf("%d",&rows);	
for(i=1;i<=rows;++i)	
{	
for(space=1;space<=rows-i;++space)	
{	
printf(" ");	
}	
while(k!=2*i-1)	
{	
printf("* ");	
++k;	
}	
k=0;	
printf("\n");	
}	
return 0;	
}

用 * 打印倒金字塔

* * * * * * * * *

源代码:

#include<stdio.h>	
int main()	
{	
int rows,i,j,space;	
printf("Enter number of rows: ");	
scanf("%d",&rows);	
for(i=rows;i>=1;--i)	
{	
for(space=0;space<rows-i;++space)	
printf(" ");	
for(j=i;j<=2*i-1;++j)	
printf("* ");	
for(j=0;j<i-1;++j)	
printf("* ");	
printf("\n");	
}	
return 0;	
}

5、简单的加减乘除计算器

源代码:

/* Source code to create a simple calculator for addition, subtraction, multiplication and division using switch...case statement in C programming. */	# include <stdio.h>	
int main()	
{	
char o;	
float num1,num2;	
printf("Enter operator either + or - or * or divide : ");	
scanf("%c",&o);	
printf("Enter two operands: ");	
scanf("%f%f",&num1,&num2);	
switch(o) {	
case '+':	
printf("%.1f + %.1f = %.1f",num1, num2, num1+num2);	
break;	
case '-':	
printf("%.1f - %.1f = %.1f",num1, num2, num1-num2);	
break;	
case '*':	
printf("%.1f * %.1f = %.1f",num1, num2, num1*num2);	
break;	
case '/':	
printf("%.1f / %.1f = %.1f",num1, num2, num1/num2);	
break;	
default:	
/* If operator is other than +, -, * or /, error message is shown */	
printf("Error! operator is not correct");	
break;	
}	
return 0;	
}

结果输出:

Enter operator either + or - or * or divide : -

6、检查一个数能不能表示成两个质数之和

源代码:

#include <stdio.h>	
int prime(int n);	
int main()	
{	
int n, i, flag=0;	
printf("Enter a positive integer: ");	
scanf("%d",&n);	
for(i=2; i<=n/2; ++i)	
{	
if (prime(i)!=0)	
{	
if ( prime(n-i)!=0)	
{	
printf("%d = %d + %d\n", n, i, n-i);	
flag=1;	
}	}	
}	
if (flag==0)	
printf("%d can't be expressed as sum of two prime numbers.",n);	
return 0;	
}	
int prime(int n) /* Function to check prime number */	
{	
int i, flag=1;	
for(i=2; i<=n/2; ++i)	
if(n%i==0)	
flag=0;	
return flag;	
}

结果输出:

Enter a positive integer: 34

7、用递归的方式颠倒字符串

源代码:

/* Example to reverse a sentence entered by user without using strings. */	#include <stdio.h>	
void Reverse();	
int main()	
{	
printf("Enter a sentence: ");	
Reverse();	
return 0;	
}	
void Reverse()	
{	
char c;	
scanf("%c",&c);	
if( c != '\n')	
{	
Reverse();	
printf("%c",c);	
}	
}

结果输出:

Enter a sentence: margorp emosewa

8、实现二进制与十进制之间的相互转换

/* C programming source code to convert either binary to decimal or decimal to binary according to data entered by user. */	
#include <stdio.h>	
#include <math.h>	
int binary_decimal(int n);	
int decimal_binary(int n);	
int main()	
{	
int n;	
char c;	
printf("Instructions:\n");	
printf("1. Enter alphabet 'd' to convert binary to decimal.\n");	
printf("2. Enter alphabet 'b' to convert decimal to binary.\n");	
scanf("%c",&c);	
if (c =='d' || c == 'D')	
{	
printf("Enter a binary number: ");	
scanf("%d", &n);	
printf("%d in binary = %d in decimal", n, binary_decimal(n));	
}	
if (c =='b' || c == 'B')	
{	
printf("Enter a decimal number: ");	
scanf("%d", &n);	
printf("%d in decimal = %d in binary", n, decimal_binary(n));	
}	
return 0;	
}	
int decimal_binary(int n) /* Function to convert decimal to binary.*/	
{	
int rem, i=1, binary=0;	
while (n!=0)	
{	
rem=n%2;	
n/=2;	
binary+=rem*i;	
i*=10;	
}	
return binary;	
}	
int binary_decimal(int n) /* Function to convert binary to decimal.*/	
{	
int decimal=0, i=0, rem;	
while (n!=0)	
{	
rem = n%10;	
n/=10;	
decimal += rem*pow(2,i);	
++i;	
}	
return decimal;	
}

结果输出:

9、使用多维数组实现两个矩阵的相加

源代码:

#include <stdio.h>	
int main(){	
int r,c,a[100][100],b[100][100],sum[100][100],i,j;	
printf("Enter number of rows (between 1 and 100): ");	
scanf("%d",&r);	
printf("Enter number of columns (between 1 and 100): ");	
scanf("%d",&c);	
printf("\nEnter elements of 1st matrix:\n");	
/* Storing elements of first matrix entered by user. */	
for(i=0;i<r;++i)	
for(j=0;j<c;++j)	
{	
printf("Enter element a%d%d: ",i+1,j+1);	
scanf("%d",&a[i][j]);	
}	
/* Storing elements of second matrix entered by user. */	
printf("Enter elements of 2nd matrix:\n");	
for(i=0;i<r;++i)	
for(j=0;j<c;++j)	
{	
printf("Enter element a%d%d: ",i+1,j+1);	
scanf("%d",&b[i][j]);	
}	
/*Adding Two matrices */	
for(i=0;i<r;++i)	
for(j=0;j<c;++j)	
sum[i][j]=a[i][j]+b[i][j];	
/* Displaying the resultant sum matrix. */	
printf("\nSum of two matrix is: \n\n");	
for(i=0;i<r;++i)	
for(j=0;j<c;++j)	
{	
printf("%d ",sum[i][j]);	
if(j==c-1)	
printf("\n\n");	
}	
return 0;	
}

10、矩阵转置

源代码:

#include <stdio.h>	
int main()	
{int a[10][10], trans[10][10], r, c, i, j;	
printf("Enter rows and column of matrix: ");	
scanf("%d %d", &r, &c);	
/* Storing element of matrix entered by user in array a[][]. */	
printf("\nEnter elements of matrix:\n");	
for(i=0; i<r; ++i)	
for(j=0; j<c; ++j)	
{	
printf("Enter elements a%d%d: ",i+1,j+1);	
scanf("%d",&a[i][j]);	
}	
/* Displaying the matrix a[][] */	
printf("\nEntered Matrix: \n");	
for(i=0; i<r; ++i)	
for(j=0; j<c; ++j)	
{	
printf("%d ",a[i][j]);	
if(j==c-1)	
printf("\n\n");	
}	
/* Finding transpose of matrix a[][] and storing it in array trans[][]. */	
for(i=0; i<r; ++i)	
for(j=0; j<c; ++j)	
{	
trans[j][i]=a[i][j];	
}	
/* Displaying the transpose,i.e, Displaying array trans[][]. */	
printf("\nTranspose of Matrix:\n");	
for(i=0; i<c; ++i)	
for(j=0; j<r; ++j)	
{	
printf("%d ",trans[i][j]);	
if(j==r-1)	
printf("\n\n");	
}	
return 0;	
}

640?wx_fmt=png

640?wx_fmt=png

它,

不仅仅是一个码

扫码关注

C++资源免费送

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/339337.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++实现简单的信息管理系统

本文为大家分享C实现简单的信息管理系统&#xff0c;小编之前在学习的时候也要做一些管理系统&#xff0c;在网上查了许多资料&#xff0c;现在我把资料分享给大家&#xff0c;希望能够帮助到大家。#include <stdio.h> #include <stdlib.h> #include "file.…

C# 面向对象三大特性:封装、继承、多态

面向对象有封装、继承、多态这三个特性&#xff0c;面向对象编程按照现实世界的特点来管理复杂的事物&#xff0c;把它们抽象为对象&#xff0c;具有自己的状态和行为&#xff0c;通过对消息的反应来完成任务。这种编程方法提供了非常强大的多样性&#xff0c;大大增加了代码的…

行车记录仪设置php,行车记录仪怎么调设置

行车记录仪设置方法如下&#xff1b;1、视频分辨率视频分辨率一直是厂家着力宣传的卖点&#xff0c;从最初的高清720P、全高清1080P到现在的超高清2K&#xff0c;车主朋友们也都耳熟能详。一般行车记录仪的分辨率提供以下几个选项&#xff1a;1080FHD、720P、WVGA、VGA。视频分…

C++面试常见问题整理汇总(面试者必看哦!)

1. 继承方式public   父类的访问级别不变#include <iostream> using namespace std; class base { public: void printa() { cout <<"base"<< endl; } protected: void printhello() { cout <<"helo"<< endl; } p…

C++ vector使用的一些注意事项

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;1. 初始化c 11以后新增了大括号{}的初始化方式&#xff0c;需要注意与()的区别,如&#xff1a;std::vector<int> vecTest1(5); //初始化5个元素&#xff0c;每个都是0std::vector<int> vecTest2{ 5…

最全的C++面试题来啦!(来自各大一线互联网)

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;此面试题全部由成功就业学员提供&#xff0c;来自各大一线互联网企业&#xff0c;在此谢谢他们的贡献&#xff01;1.new、delete、malloc、free关系delete会调用对象的析构函数,和new对应free只会释放内存&#xff0c;n…

基于C++实现五子棋AI算法思想

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;今天我想要分享一下我做五子棋AI的思路。因为在做这个之前&#xff0c;我没有接触过任何像这种类似的东西。通过这一次&#xff0c;我也算是有所了解&#xff0c;我的思路也是来自很多网络上的博客&#xff0c;看了很多…

java代码初体验_第一次Java 8体验

java代码初体验像世界其他地方一样&#xff0c;我深深地爱上了Slack。 为什么&#xff1f; 原因很多&#xff0c;但主要的原因是它提供了一种围绕通讯而非工具真正构建SDLC流程的新方法。 您认为这些天哪个更常见&#xff0c;杂乱无章的机智团队在荒野中四处徘徊&#xff0c;尽…

C++学习 | 面试官:我们只想要这样的C++工程师

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;最近好多同学来找就就说&#xff0c;我想找 xxx 方向的工作&#xff0c;我怎么学习呀&#xff1f;我也不知道这个岗位的招聘要求是啥&#xff1f;这个很正常哈&#xff0c;主要是咱们平时很少去关注企业的招聘要求&…

C语言开发推箱子游戏项目实战

C语言能做什么&#xff1f;相信学过C语言的各位都会有一个疑问&#xff0c;我们学了C语言到底可以做什么&#xff1f;或许有人会说做系统开发、驱动开发等等&#xff0c;但是这个感觉离我们好远&#xff0c;甚至于我们学C语言都仅仅是为了用程序做数学题&#xff0c;要不就是用…

dw php如何传递id参数6,[php] 我的微型论坛的简单教程[已完成]第6/8页

现在数据库中还没有数据&#xff0c;所以&#xff0c;我们运行首页&#xff0c;只显示“对不起&#xff0c;论坛尚在建设中……”。既然我们很希望看到结果&#xff0c;就往数据库中加几条数据吧&#xff01;&#xff01;当然&#xff0c;直接在MySQL客户端运行查询语句"i…

尺度不变性是指什么不变_不变性如何提供帮助

尺度不变性是指什么不变在最近的几篇文章中&#xff0c;包括“ Getters / Setters。 邪恶。 期。” &#xff0c; “对象应该是不可变的”和“依赖注入容器是代码污染者” &#xff0c;我普遍将所有可变对象标记为“ setter”&#xff08;以set开头的对象方法&#xff09;。 我…

java prototype是什么,java设计模式-原型模式(Prototype)

定义原型模式属于对象的创建模式。通过给出一个原型对象来指明所有创建的对象的类型&#xff0c;然后用复制这个原型对象的办法创建出更多同类型的对象。这就是原型模式的用意原型模式的结构原型模式要求对象实现同一个可以“克隆”自身的接口&#xff0c;遮掩个就可以通过赋值…

Windows 动态链接库 DLL 浅析

一、概念DLL&#xff1a;Dynamic Link Library&#xff0c;即动态链接库&#xff0c;这种库包含了可由多个程序同时使用的代码和数据。它是microsoft在windows操作系统中实现共享函数库概念的一种实现方式。其中windows中 一些作为DLL实现的文件有&#xff1a;ActiveX控件&…

图片大小 媒体大小自适应_自适应堆大小

图片大小 媒体大小自适应在改进测试平台以改进Plumbr GC问题检测器的同时 &#xff0c;我最终编写了一个小型测试用例&#xff0c;我认为这对于更广泛的读者来说可能很有趣。 我追求的目标是测试JVM在eden&#xff0c;survivor和Tenured空间之间如何分割堆方面的自适应性。 测…

如何优雅的激怒C/C++程序员

一、想知道怎么激怒C/C程序员及爱好者吗&#xff1f;那就来一起看看吧&#xff1a;C是一个编译很快&#xff0c;但运行很慢的语言。对此我不接受反驳&#xff0c;C我早就精通了。你问我需要多久才能精通&#xff0c;只要14天。前13天学C&#xff0c;最后1天看看面向对象就行。C…

java xml格式打包,maven项目打包xml没有被打包解决办法 ,mybatis的xml打包

在打maven包是遇见一个问题&#xff1a;打完包发现src/main/java中的的mapping没有被打包进去&#xff1b;原因主要是mapping目录里面的文件都是xml文件并不是.java文件&#xff0c;而maven打包默认的src/main/java的是Java文件&#xff0c;它不会打包里面的xml文件&#xff0c…

老司机找BUG指南,赶紧拿走。。

一.码畜&#xff1a;靠编译器帮自己查语法错误消灭笔误:编写适合程序员的键盘练习if (常量变量或表达式)使用goto接力超长的if,switch连续的if还是if elseif多个条件的组合:精心的排版多重括号的匹配条件编译各种const:不要纠结各种常量了&#xff0c;这个世界上唯一不变的就是…

红帽 jboss_红帽JBoss BRMS和BPMS富客户端框架展示了与GWT / Errai / UberFire和AngularJS的多语言集成...

红帽 jboss上周&#xff0c;我发布了一个博客&#xff0c;重点介绍了我的演示文稿&#xff0c;该演示文稿展示了我们在BRMS和BPMS平台内完成的工作&#xff0c;Drools和jBPM项目的产品化版本所产生的丰富客户端平台。 该演示文稿是所有屏幕截图和视频&#xff0c;您可以在此处找…

你知道自己适合做程序员吗?

哪有什么适不适合?编码本来就不是一件复杂的事情&#xff0c;日常工作不就是敲码、找Bug、 跟产品经理吵架、终于下班了、回家改BUG吗?今天看到了最奇葩的辞职理由&#xff1a;我觉得我数学不好&#xff0c;我不想做编程 我坐不住&#xff0c;我不想做编程 我性格太活泼&…