今天本人正在看算法方面的书。作为高中数学忘得差不多的渣渣,实在无力。无奈找了本书,c语言写的,哎。我就把其中代码翻译成C#版好了。此坑能否填平,看我耐性和网络支持条件吧。有生之年能看完的话我会把整个项目上传的。

那就开坑吧。为了直观性舍弃代码规范性,所以如果有人不幸看到,不要吐槽,谢谢。

从第一章开始。

public class _1_1看商品猜价格

    {

        public void 看商品猜价格()

        {

            Console.WriteLine("设置商品真实价格");

            int 真正价格 = int.Parse(Console.ReadLine());

            Console.WriteLine("设置猜测价格");

            int 猜测价格 = int.Parse(Console.ReadLine());

            int 猜测次数 = ;

            while (猜测价格 != 真正价格)

            {

                猜测次数++;

                Console.WriteLine("继续猜");

                猜测价格 = int.Parse(Console.ReadLine());

            }

            Console.WriteLine("你猜了" + 猜测次数+"次才猜中");

            //Console.WriteLine("  ");

        }

    }

public class _1_2斐波那契数列

    {

        public long i = ;

        public void 计算斐波那契数列()

        {

            //1.3.2 顺推实例:斐波那契数列

            Console.WriteLine("设置N");

            long N = long.Parse(Console.ReadLine());

            tailrecursion(, , N);

            //long sum = 0;

            //for (long i = 0; i <= N; i++)

            //{

            //    Console.WriteLine(i + " " + sum);

            //    sum += 斐波那契数列(i);            

            //} 

        }

        public void tailrecursion(long a, long b, long n)

        {

            if (n==)

            {

                return;

            }           

            i++;

            Console.WriteLine(i + " " + (a + b)); 

            tailrecursion(b,a+b, n - );

            n--;

        }

        public long 斐波那契数列(long n)

        {

            if (n <= )

            {

                return ;

            }

            else

            {

                return 斐波那契数列(n - ) + 斐波那契数列(n - );

            }     

        }

    }

实现了2种

网上那种 计算斐波那契数列的C#实现(注释的代码)完全是垃圾!垃圾的地方在于递归方法调用2次,在N越来越大的时候非常明显,而用尾递归(tailrecursion
的话飞速算完。不幸的原文用的就是我注释的那部分方法。

class _1_3用逆推法求最初存钱数

    {

       public void 求最初存钱数()

        {

            int 本息 = ;

            Double 年利率 = 0.0171;

            double[] 本利合计 =new double[];

            int i;

            本利合计[] = 本息;

            for ( i = ;i > ; i--)

            {

                本利合计[i] = (本利合计[i + ] + 本息) / ( + 年利率/);                  

            }

            for ( i = ; i > ; i--)

            {

                Console.WriteLine("第"+i+"月末本利合计:"+本利合计[i]);    

            }

            

        }       

    }

class _1_4用枚举法完成填数游戏

    {

        public void 用枚举法完成填数游戏()

        {

            int i1, i2, i3, i4, i5;

            long multi, result;

            for (i1 = ; i1 <= ; i1++)

            {

                for (i2 = ; i2 <= ; i2++)

                {

                    for (i3 = ; i3 <= ; i3++)

                    {

                        for (i4 = ; i4 <= ; i4++)

                        {

                            for (i5 = ; i5 <= ; i5++)

                            {

                                multi = i1 *  + i2 *  + i3 *  + i4 *  + i5;

                                result = i5 * ;

                                if (multi * i1 == result)

                                {

                                    Console.WriteLine(i1 + "" + i2 + "" + i3 + "" + i4 + "" + i5);

                                    Console.WriteLine("X" + i1);

                                    Console.WriteLine("____________");

                                    Console.WriteLine(i5 + "" + i5 + "" + i5 + "" + i5 + "" + i5 + "" + i5);

                                }

                            }

                        }

                    }

                }

            }

        }

    }

1-6使用递归算法计算阶乘

            int i;
            Console.WriteLine("请输入要求阶乘的一个整数:");
            i = int.Parse(Console.ReadLine());
            Console.WriteLine(i+"的阶乘结果为:"+fact(i));
        }
        int fact(int n)
        {
            if (n <= )
                return ;
            else
                return n * fact(n - );
        }

1_8兵乓球比赛日程安排

        int[,] a = new int[, ];
        public void Run()
        {
            int m, i, j;
            Console.WriteLine("输入参赛选手人数:");
            m = int.Parse(Console.ReadLine());
            j = ;
            for (i = ; i < ; i++)
            {
                j = j * ;
                if (j == m)
                    break;
            }
            if (i >= )
            {
                Console.Write("参赛选手人数必须为2的整数次幂,且不超过64!\n");
            }
            gamecal(, m);
            Console.Write("\n编号");
            for (i = ; i <= m; i++)
            {
                Console.Write( i - +"天 ");
            }
            Console.WriteLine("\n");
            for (i = ; i <= m; i++)
            {
                for (j = ; j <= m; j++)
                    Console.Write(" " + a[i, j] + " ");
                Console.Write("\n");
            }
        }
        private void gamecal(int k, int n)
        {             int i, j;
            if (n == )
            {
                a[k, ] = k;  //参赛选手编号
                a[k, ] = k + ; //对阵选手编号
                a[k + , ] = k + ; //参赛选手编号 
                a[k + , ] = k; //对阵选手编号 
            }
            else
            {
                gamecal(k, n / );
                gamecal(k + n / , n / );
                for (i = k; i < k + n / ; i++) //填充右上角 
                {
                    for (j = n /  + ; j <= n; j++)
                    {
                        a[i, j] = a[i + n / , j - n / ];
                    }
                }
                for (i = k + n / ; i < k + n; i++) //填充左下角 
                {
                    for (j = n /  + ; j <= n; j++)
                    {
                        a[i, j] = a[i - n / , j - n / ];
                    }
                }
            }
        }

1-9用贪婪算法求找零钱

1-11用试探法生成彩票组合

1-12模拟法猜数游戏

1-13模拟法掷骰子游戏

DDD

零基础学C#算法(零基础学算法——C#版)的更多相关文章

  1. 答好友困惑:Java零基础如何入门,不知道怎么学,迷茫ING

    作者:程序员小跃 几个星期之前,我在知乎上看到一个提问,说是:对于完全没有经验零基础自身的数学底子也很弱学习Java应该怎么学习呢?想着类似的问题我也有过回答,并且反馈还是蛮好的,就参考之前的思路回答 ...

  2. JVM基础系列开篇:为什么要学虚拟机?

    跟许多人一样,我一开始接触 Java 虚拟机只是因为面试需要用到,所以硬着头皮看看.所以很多人对于为什么要学虚拟机这个问题,他们的答案都是:因为面试.但我经过了几年的学习和实战,我发现其实学习虚拟机并 ...

  3. 1、JavaScript 基础一 (从零学习JavaScript)

    1:定义:javascript是一种弱类型.动态类型.解释型的脚本语言. 弱类型:类型检查不严格,偏向于容忍隐式类型转换. 强类型:类型检查严格,偏向于不容忍隐式类型转换. 动态类型:运行的时候执行类 ...

  4. 从头开始学JavaScript 笔记(一)——基础中的基础

    原文:从头开始学JavaScript 笔记(一)--基础中的基础 概要:javascript的组成. 各个组成部分的作用 . 一.javascript的组成   javascript   ECMASc ...

  5. 学unity3d需要什么基础

    学unity3d需要什么基础?在游戏业发展如火如荼的情境下,很多人开始转行投身于游戏程序开发,而unity3D游戏开发则是他们必须了解和会用的游戏开发工具.在学习之前又应该了解哪些内容呢? unity ...

  6. 2、JavaScript 基础二 (从零学习JavaScript)

     11.强制转换 强制转换主要指使用Number.String和Boolean三个构造函数,手动将各种类型的值,转换成数字.字符串或者布尔值. 1>Number强制转换 参数为原始类型值的转换规 ...

  7. 学hadoop需要什么基础

    最近一段时间一直在接触关于hadoop方面的内容,从刚接触时的一片空白,到现在也能够说清楚一些问题.这中间到底经历过什么只怕也就是只有经过的人才会体会到吧.前几天看到有个人问“学hadoop需要什么基 ...

  8. [区块链] 密码学中Hash算法(基础)

    在介绍Hash算法之前,先给大家来个数据结构中对hash表(散列表)的简单解释,然后我再逐步深入,讲解一下hash算法. 一.Hash原理——基础篇 1.1 概念 哈希表就是一种以 键-值(key-i ...

  9. Android版数据结构与算法(一):基础简介

    版权声明:本文出自汪磊的博客,未经作者允许禁止转载. 一.前言 项目进入收尾阶段,忙忙碌碌将近一个多月吧,还好,不算太难,就是麻烦点. 数据结构与算法这个系列早就想写了,一是梳理总结,顺便逼迫自己把一 ...

  10. JVM垃圾回收(三)- GC算法:基础

    GC算法:基础 在介绍GC算法在实际场景中的实现之前,我们先定义一些必要的术语,以及GC算法的基本准则.具体的细节会因收集器的不同而稍有区别,但是基本上来说,所有的收集器会关注以下两个方面: 找出所有 ...

随机推荐

  1. [原创] 基础中的基础(二):C/C++ 中 const 修饰符用法总结

    在这篇文章中,我总结了一些C/C++语言中的 const 修饰符的常见用法,供大家参考. const 的用法,也是技术性面试中常见的基础问题,希望能够帮大家梳理一下知识,给大家一点点帮助.作者是菜鸟一 ...

  2. BZOJ4825: [Hnoi2017]单旋(Splay)

    题面 传送门 题解 调了好几个小时--指针太难写了-- 因为只单旋最值,我们以单旋\(\min\)为例,那么\(\min\)是没有左子树的,而它旋到根之后,它的深度变为\(1\),它的右子树里所有节点 ...

  3. sublime text 给选中项插入编号

    #coding=utf-8 import datetime, getpass import sublime, sublime_plugin import re # 插数字 class InsertNu ...

  4. 80端口被系统进程PID-4占用解决办法

    今天因为工程需要就把tomcat服务器的端口改成了80了,可是一启动就出现问题了 发现报错信息是端口占用了,于是我马上就在了命令行敲入了netstat -ano查看端口占用情况 终于发现是PID为4的 ...

  5. zoj4020 Traffic Light(bfs+状态压缩)

    题意:每个点有两种状态,0/1,0表示只能上下方向走,1表示只能左右方向走.每走一步整个图的状态改变一次(即0->1,1->0). 数据范围:n,m<=1e15 开始迷之因为数组太大 ...

  6. Mutual Training for Wannafly Union #6 E - Summer Trip(并查集)

    题目链接:http://www.spoj.com/problems/IAPCR2F/en/ 题目大意: 给m个数字代表的大小,之后n组数据,两两关联,关联后的所有数字为一组,从小到大输出组数以及对应的 ...

  7. elasticsearch geo_point 地理位置过滤 按经度排序

    elasticsearch 支持强大的经纬度坐标过滤. 1.首先要建立坐标类型的字段'type' ='geo_point' es存储的值是这样的: "poi": [        ...

  8. Chrome谷歌浏览器已停用不支持的扩展程序解决方法

    在不能上外网的情况下解决该问题: http://www.liu16.com/post/Chrome_2447.html

  9. linux下oracle数据库字符集修改

    linux下oracle数据库字符集修改 0.RHEL6.7.oracle11gr2 1.登录oracle.在安装oracle的用户下进入数据库. $ sqlplus / as sysdba 2.查询 ...

  10. 放弃jQuery,使用原生js吧!

    转自:http://itakeo.com/blog/2015/07/28/nojq/ 随着IE6.7.8的逐渐淘汰,HTML5的兴起,以及侧重点放在了移动端,jQuery可能变的不在那么重要,原生一样 ...