swift算法手记-5

//
//  ViewController.swift
//  learn5
//
//  Created by myhaspl on 16/1/23.
//  Copyright (c) 2016年 myhaspl. All rights reserved.
//

import Cocoa
import Foundation

class ViewController: NSViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.
    }

    override var representedObject: AnyObject?

{ didSet { // Update the view, if already loaded. } } private func comresult(inputnum:Double)->Double{ // 5*x^7-3*x^5+16*x^2+7*x+90=0 let myresult:Double = 5 * pow(inputnum,7) - 3 * pow(inputnum,5) + 16 * pow(inputnum,2) + 7 * inputnum + 90 return myresult } @IBOutlet weak var result: NSTextField! @IBAction func compute(sender: AnyObject){ // 5*x^7-3*x^5+16*x^2+7*x+90=0 // 二分法求一元方程的解,最大求解范围[-100000,100000] let trycount = 80 var accuracy: Double = 0.00000000000001 var answer: Double?

=nil // 预计解范围 var leftbound:Double?=nil var rightbound:Double?=nil for var bound:Double=1;bound<10000000;bound*=10{ let leftres=comresult(-bound) let rightres=comresult(bound) if (leftres*rightres) < 0 { leftbound = (-bound) rightbound = bound break } } if (leftbound==nil || rightbound==nil){ return } //计算方程的解 for i in 1...trycount{ result.stringValue=String(i) let center=leftbound!+(rightbound!-leftbound!)/2 let leftres:Double=comresult(leftbound!) let rightres:Double=comresult(rightbound!) let centres:Double=comresult(center) if centres==0 { answer=center break } else if abs(rightbound!-leftbound!) < accuracy { answer=leftbound! break } else if leftres*centres<0{ rightbound=center } else if rightres*centres<0{ leftbound=center } } if let ans=answer{ //方程有解 result.stringValue="解:"+String(stringInterpolationSegment: ans)+" " result.stringValue += "解代入方程的值:"+String(stringInterpolationSegment:comresult(ans)) } } }



本博客全部内容是原创。假设转载请注明来源

http://blog.csdn.net/myhaspl/



转载于:https://www.cnblogs.com/ljbguanli/p/7392215.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值