一个关于四位数猜想的验证

摘要:有这样一个猜想:给定一个四位数,abcd找出abcd组合成的最大数和最小数,然后相减,然后得到一个新的四位数,重复该过程,不超过8次即可得到一个固定的数6174;现在用c语言进行验证;
(1)首先需要构建的函数是找到一个四位数最大或者最小的组合;对于任意四位数,利用取余数求出每个位,然后利用桶式排序得到一个排序的序列,顺序或倒序求出形成的四位数.

int FindMax(int Number)
{
    int S[4] = {0};
    int Order[10] = {0};
    for (int i = 0;i<=3;i++)
    {
        S[i] = Number%10;
        Order[S[i]]++;
         Number /= 10;
    }
    Number = 0;
    for(int i =9;i>=0;i--)
    {
        if(Order[i]!=0)
        {
        while(Order[i]--)
        Number = 10*Number +i;//从小到大
        }
    }

    return Number;
}
int FindMin(int Number)
{
    int S[4] = {0};
    int Order[10] = {0};
    for (int i = 0;i<=3;i++)
    {
        S[i] = Number%10;
        Order[S[i]]++;
         Number /= 10;
    }
    Number = 0;
    for(int i =0;i<=9;i++)
    {
        if(Order[i]!=0)
        {
        while(Order[i]--)
        Number = 10*Number +i;//从小到大
        }
    }
    return Number;
}

(2)对于每个四位数进行验证,利用递归的思路,并且传递变量times(规定次数内求解出)限制边界条件可以得到结果.

void Check(int Number,int times)
{
    int Max = FindMax(Number);
    int Min = FindMin(Number);
    int OldNumber = Max - Min;
    if (Number == OldNumber && times<=8)
        printf("\nthe Number %d is okay,times is %d",Number,times);
    else if (times < 8)
    Check(OldNumber,times+1);
    else
        printf("\nthe Number: %d failed",Number);
}
int _tmain(int argc, _TCHAR* argv[])
{
    int number ;
    for (number = 1000;number<=9999;number++)
        Check(number,1);
    return 0;
}

这里写图片描述

//得到随机字符串,长度自己定义 private string getRandomValidate(int len) { int num; int tem; string rtuStr = ""; for (int i = 0; i < len; i++) { num = ran.Next(); /* * 这里可以选择生成字符和数字组合的验证码 */ tem = num % 10 + '0';//生成数字 // tem = num % 26 + 'A';//生成字符 rtuStr += Convert.ToChar(tem).ToString(); } return rtuStr; } //生成图像 private void getImageValidate(string strValue) { //string str = "OO00"; //前两个为字母O,后两个为数字0 int width = Convert.ToInt32(strValue.Length * 12); //计算图像宽度 Bitmap img = new Bitmap(width, 23); Graphics gfc = Graphics.FromImage(img); //产生Graphics对象,进行画图 gfc.Clear(Color.White); drawLine(gfc, img); //写验证码,需要定义Font Font font = new Font("arial", 12, FontStyle.Bold); System.Drawing.Drawing2D.LinearGradientBrush brush = new System.Drawing.Drawing2D.LinearGradientBrush(new Rectangle(0, 0, img.Width, img.Height), Color.DarkOrchid, Color.Blue, 1.5f, true); gfc.DrawString(strValue, font, brush, 3, 2); drawPoint(img); gfc.DrawRectangle(new Pen(Color.DarkBlue), 0, 0, img.Width - 1, img.Height - 1); //将图像添加到页面 MemoryStream ms = new MemoryStream(); img.Save(ms, System.Drawing.Imaging.ImageFormat.Gif); //更改Http头 Response.ClearContent(); Response.ContentType = "image/gif"; Response.BinaryWrite(ms.ToArray()); //Dispose gfc.Dispose(); img.Dispose(); Response.End(); } private void drawLine(Graphics gfc, Bitmap img) { //选择画10条线,也可以增加,也可以不要线,只要随机杂点即可 for (int i = 0; i < 10; i++) { int x1 = ran.Next(img.Width); int y1 = ran.Next(img.Height); int x2 = ran.Next(img.Width); int y2 = ran.Next(img.Height); gfc.DrawLine(new Pen(Color.Silver), x1, y1, x2, y2); //注意画笔一定要浅颜色,否则验证码看不清楚 } } private void drawPoint(Bitmap img) { /* //选择画100个点,可以根据实际情况改变 for (int i = 0; i < 100; i++) { int x = ran.Next(img.Width); int y = ran.Next(img.Height); img.SetPixel(x,y,Color.FromArgb(ran.Next()));//杂点颜色随机 }*/ int col = ran.Next();//在一次的图片中杂店颜色相同 for (int i = 0; i < 100; i++) { int x = ran.Next(img.Width); int y = ran.Next(img.Height); img.SetPixel(x, y, Color.FromArgb(col)); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值