Python——求整数反码(采用除2取余方法实现)(tkinter实现)【2022-01-22】

Python——求整数反码(采用除2取余方法实现)(tkinter实现)【2022-01-22】,第1张

Python——求整数反码(采用除2取余方法实现)(tkinter实现)【2022-01-22】

Python——求整数反码(采用除2取余方法实现)(tkinter实现)

1.qfm.py2.结果示例

[功能模块作者]
CSDN用户(TDTX),TDTX主页——负责求整数反码功能

【求整数原码】采用除2取余的方法,逐步形成列表,最后逆转列表即可。
【求原码】Python——求整数原码(采用除2取余方法实现)(tkinter实现)
【注】如果某整数求得原码是6位,则根据是正或负,在第7位添加0或1即可。
          即不设置固定位数的显示模式。
          据此得到的原码来求反码。

1.qfm.py
def qfm():
    import tkinter as tk
    fmwindow=tk.Tk()
    fmwindow.title("求反码")
    fmwindow.geometry("650x850")
    def sfhf():
        f=e1.get()
    def szsf():
        s=eval(e2.get())
    def xsqfm():
        f=e1.get()
        s=eval(e2.get())
        s0=s
        sp=[]
        fp=[]
        co=0
        if f=='+':
            if s==0:
                tx.insert('insert',"n+{0}计算过程:n0n00n".format(s0))
                tx.insert('insert',"+0反码为:n")
                tx.insert('insert',"00n")
            else:
                tx.insert('insert',"n+{0}计算过程:n".format(s0))
                while s>0:
                    x=s%2
                    sp.append(x)
                    s=s//2
                    tx.insert('insert',"{0}n".format(sp))
                sp.reverse()
                sp.insert(0,0)
                tx.insert('insert',"+{0}反码为:n".format(s0))
                tx.insert('insert',"{0}n".format(sp))
        if f=='-':
            if s==0:
                tx.insert('insert',"n-{0}计算过程:n1n11n".format(s0))
                tx.insert('insert',"-0反码为:n")
                tx.insert('insert',"11n")
            else:
                while s>0:
                    x=s%2
                    sp.append(x)
                    s=s//2
                sp.reverse()
                sp.insert(0,1)
#            print(sp)
                tx.insert('insert',"n-{0}计算过程:n".format(s0))
                for i in sp:
                    if co!=0:
                        if i==0:
                            fp.append(1)
                            tx.insert('insert',"{0}n".format(fp))
                        elif i==1:
                            fp.append(0)
                            tx.insert('insert',"{0}n".format(fp))
                    elif co==0:
                        fp.append(i)
                        tx.insert('insert',"{0}n".format(fp))
                    co=co+1
                tx.insert('insert',"n-{0}反码为:n".format(s0))
                tx.insert('insert',"{0}n".format(fp))
    lb1=tk.Label(fmwindow, text='输入整数的符号(+/-)', bg='orange', font=('Arial', 12), width=30)
    lb1.pack()
    e1 = tk.Entry(fmwindow,font=('Arial', 14))
    e1.pack()
    bt1=tk.Button(fmwindow,text='确认符号',width=10,font=('Arial', 12),command=sfhf)
    bt1.pack()
    
    lb2=tk.Label(fmwindow, text='输入整数(不带符号)', bg='orange', font=('Arial', 12), width=30)
    lb2.pack()
    e2 = tk.Entry(fmwindow,font=('Arial', 14))
    e2.pack()
    bt2=tk.Button(fmwindow,text='确认数字',width=10,font=('Arial', 12),command=szsf)
    bt2.pack()
    
    lb3=tk.Label(fmwindow, text='---------------------------------------------', bg='orange', font=('Arial', 12), width=30)
    lb3.pack()
    bt3=tk.Button(fmwindow,text='求解反码',width=10,font=('Arial', 12),command=xsqfm)
    bt3.pack()
    
    lb4=tk.Label(fmwindow, text='结果与过程如下:', bg='orange', font=('Arial', 12), width=30)
    lb4.pack()
    tx=tk.Text(fmwindow,width=85,height=40)
    tx.pack()
    fmwindow.mainloop()
2.结果示例

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/zaji/5720539.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-18
下一篇 2022-12-18

发表评论

登录后才能评论

评论列表(0条)

保存