多种方法 实现某个数字的每一位都是n的按位数相加

5 篇文章 0 订阅

(注:开发平台:VS2017,C#语言,控制台应用)

 static void Main(string[] args)
            {
                //方法1:按顺序计算(2 + 22 + 222 ==》 2 +(2 + 2 * 10)+(2 + 22 * 10))类型的算法
                //Console.WriteLine("请输入基数:");
                //int base1 = int.Parse(Console.ReadLine());
                //Console.WriteLine("请输入次数:");
                //int count = int.Parse(Console.ReadLine());
    
            //int sum = 0;
            //int jishu = base1;
            //sum = sum + base1;
            //for (int i = 1; i < count; i++)
            //{
            //    jishu = base1 + jishu * 10;
            //    sum = sum + jishu;
            //}
            //Console.WriteLine(sum);
            //Console.ReadLine();
            // --------------------------------------------------------------------

            方法2:
            //string input;
            //int sum = 0;
            //do
            //{
            //    sum = 0;
            //    Console.WriteLine("请输入基数:");
            //    int base1 = int.Parse(Console.ReadLine());
            //    Console.WriteLine("请输入次数:");
            //    int count = int.Parse(Console.ReadLine());
            //    for (int i = 0; i < count; i++)
            //    {
            //        int cifang = 1;
            //        for (int j = 0; j < i; j++)
            //        {
            //            cifang *= 10;
            //        }
            //        sum += base1 * cifang * (count - i);
            //    }
            //    Console.WriteLine(sum);
            //    Console.WriteLine("是否继续游戏");
            //    input = Console.ReadLine();
            //} while (input != "n");
            //Console.ReadLine();
            //-----------------------------------------------------------------------

            //方法3:按位计算(2 + 22 + 222 + 2222 ==》 个位2 * 4 + 十位2 * 3 * 10 + 百位2 * 2 * 100 + 千位2 * 1 * 1000)
            //string input;
            //double sum = 0;
            //do
            //{
            //    sum = 0;
            //    Console.Write("请输入基数:");
            //    int base1 = int.Parse(Console.ReadLine());
            //    Console.Write("请输入次数:");
            //    int count = int.Parse(Console.ReadLine());
            //    int count1 = count;
            //    for (int i = 0; i < count; i++)
            //    {
            //        if (count1 > 0)
            //        {
            //            sum += 2 * count1 * Math.Pow(10, i);
            //            count1--;
            //        }

            //    }
            //    Console.WriteLine(sum);
            //    Console.WriteLine("是否继续游戏(输入n退出,否则继续)");
            //    input = Console.ReadLine();
            //} while (input != "n");
            //Console.ReadLine();
            //-----------------------------------------------------------------------------------

            // 流程输出版:(在各个变量下都添加了打印输出)
            //string input;
            //int sum = 0;
            //do
            //{
            //    sum = 0;
            //    Console.Write("请输入基数:");
            //    int base1 = int.Parse(Console.ReadLine());
            //    Console.Write("请输入次数:");
            //    int count = int.Parse(Console.ReadLine());
            //    for (int i = 0; i < count; i++)
            //    {
            //        Console.WriteLine("i=" + i);
            //        int cifang = 1;
            //        for (int j = 0; j < i; j++)
            //        {
            //            Console.WriteLine("j=" + j);
            //            cifang *= 10;
            //            Console.WriteLine("cifang=" + cifang);
            //        }
            //        sum += base1 * cifang * (count - i);
            //        Console.WriteLine("sum=" + sum + "\n");
            //    }
            //    Console.WriteLine(sum);
            //    Console.WriteLine("是否继续游戏");
            //    input = Console.ReadLine();
            //} while (input != "n");
            //Console.ReadLine();


            Console.ReadKey();

        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值