javascript实现C语言经典程序题


Posted in Javascript onNovember 29, 2015

最近在学习Javascript语言,看到网上很多都是在介绍Javascript如何解决网页上问题的代码,所以想另辟蹊径,用Javascript代码来实现C语言经典程序题。当然,这些C语言程序题也是比较简单,主要想通过Javascript语言实现,起到语法练习作用,也想来对比一下C语言和Javascript语言实现的相同点和不同点,从而巩固记忆,加强学习效果!!!

一、C语言经典程序题1

1. 题目描述:

马克思的手稿中有这样一道有趣的数学题:有30个人,其中有男人,女人,小孩。他们在一家饭馆中吃饭,共花费50先令。 如果每个男人吃饭要花3先令,每个女人要花2先令, 每个小孩要花1先令,问男人,女人,小孩各多少人?

2. Javascript代码:

var man, woman, child;
for (man = 0; man < 17; man ++) 
{
  for (woman = 0; woman <= 25; woman ++) 
  {
    child = 30 - man - woman;
    if ( (man + woman + child == 30) && (man * 3 + woman * 2 + child == 50) )
    {
      document.write("男人:"+man+","+"女人:"+woman+","+"小孩:"+child +"</br>");
    }
   }
}

3. 解题说明:

这道题目算是很经典的题目了,跟“换零钱”是同一种类型的题目,只需要多个循环加一个判断就能罗列出每一种结果。从这道题看,Javascript的代码和C语言的代码基本上没有区别,因为for语句和if语句,Javascript语言和C语言是一样的。主要的不同体现在,变量的定义和输出语句上,总体感觉Javascript语言实现起来更方便,主要原因是Javascript弱类型语言,C语言是强类型语言。

二、C语言经典程序题2

1. 题目描述:

计算e=1+1/1!+1/2!+1/3!……+1/n!的前50项

2. Javascript代码:

var n;
var s = 1;
var e = 1;
for (n = 1; n <= 50; n ++)
{
  s = s * n;
  e = e + (1 / s);
}
document.write(e);

3. 解题说明:

这道题目算是一个比较简单的题目,实现也只用了一个for循环,与C语言代码相比,区别还是在变量定义和输出上。

三、C语言经典程序题3

1. 题目描述:

输入一个数(不限位数),输出一个数字的位数。

2. Javascript代码:

<html>
<head lang="en">
  <meta charset="UTF-8">
  <title>C语言经典题目3</title>
  <script>
    function demo() {
      var n = document.getElementById("number").value;
      if (!isNaN(n)) {var len = n.length;
      }
      else{
        alert("请输入数字!");
        return;
      }
      document.getElementById("number").value = len;
    }
  </script>
</head>
<body>
  <input type="text" id="number" width="100" height="50">
  <button onclick="demo()">点我啊</button>
</body>
</html>

3. 解题说明:

这道题目比较有意思,如果用C语言实现的话,就需要不断给这个数字进行对10整除,已达到获取数字长度的目的。但Javascript语言的弱类型性质使得用Javascript解决这个题目特别简单,默认数字是字符串类型,只要判断这个字符串的长度即可。虽然有点偷懒,但也实现了功能。此外,实现这道题目也出现了和C语言不同的的东西,就是解决输入问题,C语言使用的是scanf,但Javascript没有此类函数,所以只能借助网页实现数字的输入。

四、C语言经典程序题4

1. 题目描述:

打印九九乘法表

2. Javascript代码:

function demo()
{
  var i, j, s;
  for(i = 1; i < 10; i ++)
  {
    for(j = 1; j <= i; j ++)
    {
      s = i * j;
      document.write(j+"*"+i+"="+s+" ");
    }
    document.write("<br/>");
  }
}

3. 解题说明:

这道题目也算是很经典的题目了,但实现起来特别简单,只需要两个循环嵌套就可以了。和C语言的区别除了变量定义和输出外,此处还有一个,就是换行。C语言的换行只要使用\n就可以了,但网页不识别\n,所以只能使用html的<br/>来实现换行。

五、C语言经典程序题5

1. 题目描述:

青年歌手参加歌曲大奖赛,有10个评委打分,试编程求选手的平均得分(去掉一个最高分和一个最低分)

2. Javascript代码:

<body>
<input id="getScore" type="text">
<button onclick="demo()">平均分</button>
<p id="txt"></p>
<script>
  function demo() {
    var str = document.getElementById("getScore").value;
    var score = new Array();
    score= str.split(",");
    var max = 0;
    var min = 10000;
    var sum = 0;
    var ave = 0;
    for(i=0;i<score.length;i++){
      if(score[i]>max)
      {
        max = score[i];
      }
      if(score[i]<min)
      {
        min = score[i];
      }
      sum = sum+score[i];
    }
    ave = (sum-max-min)/8;
    document.getElementById("txt").innerHTML = ave;
  }
</script>
</body>

3. 解题说明

这道题目应该算是代码数量最多的了,虽然题目很简单,但在实现输入十个成绩的时候遇到了困难,因为不能像C语言那样一个一个输入。所以,我就采用输入1,2,3,4,5,6,7,8,9,10,用逗号的方式一次性输入10个进来。输入进来后,就要对字符串进行分割了,所以用到了split函数。

五、总结

终于用Javascript语言写完了5道C语言经典题目,也算是学习Javascript的一个很好的开端。回想在解决每个题目的过程,感觉Javascript真的很C语言很像,所以入手比较简单,只是在处理输入输出的时候,有点不一样。如果让我评价,Javascript语言和C语言那个好?我会觉得Javascript真的更容易更快的解决问题,我比较喜欢它的弱类型特性,再也不用担心申明变量类型出错的问题了。当然,C语言作为永垂不朽的经典语言,当然也是很好的。

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
Jquery之Ajax运用 学习运用篇
Sep 26 Javascript
Js参数值中含有单引号或双引号问题的解决方法
Nov 06 Javascript
JavaScript禁止页面操作的示例代码
Dec 17 Javascript
Javascript浮点数乘积运算出现多位小数的解决方法
Feb 17 Javascript
简单方法判断JavaScript对象为null或者属性为空
Sep 26 Javascript
javascript用正则表达式过滤空格的实现代码
Jun 14 Javascript
angularJS Provider、factory、service详解及实例代码
Sep 21 Javascript
jquery easyui DataGrid简单示例
Jan 23 Javascript
vue 组件中添加样式不生效的解决方法
Jul 06 Javascript
原生js+canvas实现下雪效果
Aug 02 Javascript
鸿蒙系统中的 JS 开发框架
Sep 18 Javascript
vue实现lodop打印功能的示例
Nov 11 Javascript
JavaScript学习小结(7)之JS RegExp
Nov 29 #Javascript
整理Javascript基础入门学习笔记
Nov 29 #Javascript
jquery+json实现数据二级联动的方法
Nov 28 #Javascript
JavaScript实现页面跳转的几种常用方式
Nov 28 #Javascript
Javascript页面跳转常见实现方式汇总
Nov 28 #Javascript
Javascript编程之继承实例汇总
Nov 28 #Javascript
Javascript编程中几种继承方式比较分析
Nov 28 #Javascript
You might like
php simplexmlElement操作xml的命名空间实现代码
2011/01/04 PHP
PH P5.2至5.5、5.6的新增功能详解
2014/07/14 PHP
phpcms的分类名称和类别名称的调用
2017/01/05 PHP
浅析PHP类的反射来实现依赖注入过程
2018/02/06 PHP
Draggable Elements 元素拖拽功能实现代码
2011/03/30 Javascript
关于JavaScript与HTML的交互事件
2013/04/12 Javascript
document.documentElement的一些使用技巧
2013/04/18 Javascript
jquery easyui滚动条部分设置介绍
2013/09/12 Javascript
js获取某元素的class里面的css属性值代码
2014/01/16 Javascript
javascript格式化json显示实例分析
2015/04/21 Javascript
jQuery实现仿百度首页滑动伸缩展开的添加服务效果代码
2015/09/09 Javascript
怎么限制input的text里输入的值只能是数字(正则、js)
2016/05/16 Javascript
原生JavaScript编写canvas版的连连看游戏
2016/05/29 Javascript
js前端面试题及答案整理(一)
2016/08/26 Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
2017/07/12 Javascript
JavaScript递归算法生成树形菜单
2017/08/15 Javascript
js实现微信/QQ直接跳转到支付宝APP打开口令领红包功能
2018/01/09 Javascript
详解Vue单元测试Karma+Mocha学习笔记
2018/01/31 Javascript
nodeJs实现基于连接池连接mysql的方法示例
2018/02/10 NodeJs
微信小程序如何像vue一样在动态绑定类名
2018/04/17 Javascript
Bootstrap 模态框自定义点击和关闭事件详解
2018/08/10 Javascript
js实现无刷新监听URL的变化示例代码详解
2020/06/03 Javascript
Vuejs通过拖动改变元素宽度实现自适应
2020/09/02 Javascript
Python运行的17个时新手常见错误小结
2012/08/07 Python
python中bisect模块用法实例
2014/09/25 Python
Python中使用dom模块生成XML文件示例
2015/04/05 Python
使用Python设置tmpfs来加速项目的教程
2015/04/17 Python
Python使用matplotlib实现基础绘图功能示例
2018/07/03 Python
使用pyinstaller逆向.pyc文件
2019/12/20 Python
python每5分钟从kafka中提取数据的例子
2019/12/23 Python
什么是python的必选参数
2020/06/21 Python
HTML5画渐变背景图片并自动下载实现步骤
2013/11/18 HTML / CSS
英国最好的包装供应商:Priory Direct
2019/12/17 全球购物
青年文明号申报材料
2014/12/23 职场文书
2016应届毕业生实习心得体会
2015/10/09 职场文书
Nginx跨域问题解析与解决
2022/08/05 Servers