㈠ c語言 結果 出現巨大的負數
對於有符號數(分正負的),的最高位是符號位
65的二進制是
0
1000001
補碼運算為按位取反
再加1
按位取反:1
0111110
加1:
1
0111111
直接轉換為十進制的話,你把它當成無符號數把1也算了,所以不是-65
從
10111111到-65:
計算機根據符號位為1判斷是負數
按位取反:01000000
加1:
01000001
這就是65,然後是負數,就是-65
㈡ 在C語言里要輸出一個負數的值!
type(數的類型)number(你要輸出的數);
printf("% +d",number)
例如
int i=-617;
printf("% +d",i);
"+"號是輸出符號的
㈢ c語言負數的++等於多少
負數是有符號位的,在計算機中以補碼的形式儲存,最高位為1表示負數,其餘位按位取反再加1,然後你再把二進制轉換成8進制和16進制就可以了。
在c語言中,你可以用printf("%x",-617);輸出16進制
用printf("%o",-617);輸出8進制
㈣ c語言問題,為什麼會輸出負數
這個問題有多種可能,不一而足。
演算法有錯誤,最終計算結果是負數。輸出自然會是負數。
例如:
inta=1;
intb=a-2;
printf("b=%d",b);
//輸出結果:b=-1超過變數類型的最大取值范圍,發生溢出。
例如Turbo C里int是16位,取值范圍-32768~32767。如果計算過程當中,數值超過32767,由於補碼的關系。結果就有可能是負數。這種情況,就需要使用取值范圍更大的數據類型。
常式:
#include<stdio.h>
voidmain(){
inta,b,ch;
a=32767;
b=a+1;
printf("a=%d,b=%d",a,b);
ch=getch();
}
//輸出結果:a=32767,b=-32768
㈤ 在c語言中如何比較負數的大小
#include<stdio.h>
voidmain(void)
{
inta,b,c,max;
printf("inputthreerealnumbers: ");
scanf("%d%d%d",&a,&b,&c);
if(a>=b)
max=a;
else
max=b;
if(max>=c)
printf("%d",max);
else
printf("%d",c);
getch();
return0;
}
(5)c語言負數擴展閱讀
C語言signedchar型表示的數值范圍-128~127
-0和+0其實是同一個數字,因此原碼中0b10000000和0b00000000都表示數字0。現在補碼下的0隻有一個表示方式:0b00000000,二進制碼0b10000000就多餘出來了。
浪費是可恥的,多出的二進制碼0b10000000不能白白丟棄。若考慮數字0的二進制碼0b00000000,從它的符號位來看,計算機應該是將其當做「正數」的,0~127是128個「正數」。
現在考察多出的二進制碼0b10000000,從它的符號位來看,把它當做負數是合情合理的,事實上在C語言中,它表示-128,從-128到-1,恰好是128個「負數」。
㈥ 判斷某數是否為負數的程序用C語言怎麼寫
#include
int main()
{
int i;
printf("請輸入數字\n");
scanf("%d",&i);
if(i>=0)
{
printf("這個數字為非負數");
}
else
printf("這個數字為負數");
}
㈦ C語言 !(一個負數)等於啥
可以,但是結果會出錯,負數在計算機中最高位為1,作為符號標志(正數為0),但是如果賦給無符號整型變數,最高位的標志位就會變成數值位,計算時把這個1當成數值。
㈧ c語言中負數如何表示
c語言中負數表示方法就是在數前加負號「-」,比如:
-5,-10000,等
一個變數賦值為負數也是如此,比如:
x=-1000;
㈨ c語言為什麼輸入負數之後結果是錯的
兩種解決方法,你自己選擇一種:
一、
1、把long x,y;改成int x,y;
2、把所有的%ld改成%d
二、
1、把函數定義語句改為long fun(long x)
如果有不明白之處,請留言。
㈩ C語言 負號問題
只能是在程序里判斷『-』這個字元。你需要能夠判斷出『-』是一個減號還是一個負號。
比較簡單的方法是,輸入計算式時你規定好格式,負數一律用()括起來。這樣比較容易判斷是不是負數。當然你也可以定義其它的格式。
如果不規定格式的話,判斷方法稍微麻煩一點,你要判斷『-』前面是什麼,如果是數字,那麼 『-』為減號,如果是『)』,那麼『-』為減號,如果是『+-*/』號,那麼『-』為負號。如果什麼也沒有,那麼表明是起始數字,那麼『-』為負號。等等,需要考慮周全。
=======下面是一個例子==============
#include "stdafx.h"
#include<stdio.h>
#include<malloc.h>
#include<math.h>
#define maxlen 100
typedef struct node{
char ch;
int data;
struct node *next;
}LinkList;//保存表達式的鏈表
int func()
{
LinkList *ta,*tb,*tc,*td;
ta = La;
tc = Lb;
for(int n=0;n < i;n++)
{
ta=ta->next;
}
tb = ta;
for(n=0; n < Len; n++)
{
tb=tb->next;
}
ta->next = tb;
for(n=0; n < j; n++)
{
tc=tc->next;
}
td = tc->next;
tc->next =
}
typedef struct{
char stack[maxlen];
int top;
}Stack1;
typedef struct{
int stack[maxlen];
int top;
}Stack2;
int In(char c){
if((c=='+')||(c=='-')||(c=='*')||(c=='/')||(c=='#')||(c=='(')||(c==')')||(c=='A')||(c=='S'))
return 1;
else
return 0;
}
void InitStack1(Stack1 *S){
S->top=-1;
}
void InitStack2(Stack2 *S){
S->top=-1;
}
void Push1(Stack1 *S,char ch){
S->top++;
S->stack[S->top]=ch;
}
void Push2(Stack2 *S,int ch){
S->top++;
S->stack[S->top]=ch;
}
char Precede(char ch1,char ch2){//比較兩個運算符的優先順序
char ch;//當ch為<時表示ch1的優先順序要小於ch2,反之同理
switch(ch1){
case '+':if((ch2=='*')||(ch2=='/')||(ch2=='(')) ch='<';else ch='>';break;
case '-':if((ch2=='*')||(ch2=='/')||(ch2=='(')) ch='<';else ch='>';break;
case '*':if((ch2=='(')) ch='<';else ch='>';break;
case '/':if((ch2=='(')) ch='<';else ch='>';break;
case '#':if(ch2=='#') ch='=';else ch='<';break;
case '(':if(ch2==')') ch='=';else ch='<';break;
}
return ch;
}
void Pop1(Stack1 *S,char *p){
*p=S->stack[S->top];
S->top--;
}
void Pop2(Stack2 *S,int *p){
*p=S->stack[S->top];
S->top--;
}
char GetTop1(Stack1 *S){
return S->stack[S->top];
}
int GetTop2(Stack2 *S){
return S->stack[S->top];
}
void print1(Stack1 *s){
printf("運算符棧: ");
int h=s->top;
while(h!=-1){
printf("%c ",s->stack[h]);
h--;
}
printf("\n");
}
void print2(Stack2 *s){
printf("數字元棧: ");
int h=s->top;
while(h!=-1){
printf("%c ",s->stack[h]);
h--;
}
printf("\n");
}
int Operate(int a,char theta,int b){//對a和b進行運算
int s;
switch(theta){
case '+':s=a+b;break;
case '-':s=a-b;break;
case '*':s=a*b;break;
case '/':s=a/b;break;
}
return s;
}
LinkList *CreatList(){
LinkList *H,*s,*r;
H=(LinkList*)malloc(sizeof(LinkList));
H->next=NULL;
r=H;
char c;
c=getchar();
while(c!='#'){
s=(LinkList*)malloc(sizeof(LinkList));
s->ch=c;s->next=NULL;
r->next=s;r=s;
c=getchar();
}
s=(LinkList*)malloc(sizeof(LinkList));
s->ch=c;s->next=NULL;
r->next=s;r=s;
return H;
}
LinkList *Change(LinkList *H){
LinkList *p,*pre;p=H->next;pre=H;
while(p!=NULL){
if(In(p->ch)){p=p->next;pre=pre->next;}
else{ //將字元轉化成數字
int m=0,n;
while(!In(p->ch)){
n=p->ch-'0';
m=10*m+n;
LinkList *u=p;
p=p->next;
if(!In(p->ch)){ pre->next=p;free(u); }
else{ u->data=m;u->ch='@';pre=pre->next; }//@標志此節點內的符號為數字
}
}
}
return H;
}
LinkList *jisuan(LinkList *H){//對鏈表中的數據進行初步的計算
LinkList *p,*U,*pre;
p=H->next;pre=H;int a;
while(p!=NULL){
if(p->ch!='A'&&p->ch!='S'){
pre=pre->next;
p=p->next;
}
else{
if(p->ch=='A')
a=fabs(p->next->data);
else
a=sqrt(p->next->data);
p->next->data=a;
U=p;
p=U->next;
pre->next=p;
free(U);
}
}
return H;
}
int main(int argc, char* argv[])
{
printf("*******************************************************************************");
printf("\n");
printf(" 歡迎使用模擬計算器程序\n");
printf("*******************************************************************************");
Stack1 OPTR1,*OPTR=&OPTR1;
Stack2 OPTR2,*OPND=&OPTR2;
InitStack1(OPTR);
Push1(OPTR,'#');//將『#』壓入OPTR棧中
InitStack2(OPND);
char c,x,theta;
int a,b,s;
printf("請輸入表達式,以#結束:");
LinkList *H,*p,*q;
H=CreatList();
H=Change(H);
H=jisuan(H);
p=H->next;
c=p->ch;
while((c!='#')||(GetTop1(OPTR)!='#')){//#同時是表達式的截止符
if(c=='@'){
s=p->data;
Push2(OPND,s);
p=p->next;
c=p->ch;
}
else
switch(Precede(GetTop1(OPTR),c)){
case '<':Push1(OPTR,c);p=p->next;c=p->ch; break;
case '=':Pop1(OPTR,&x); p=p->next;c=p->ch; break;
case '>':Pop1(OPTR,&theta); Pop2(OPND,&b); Pop2(OPND,&a);
Push2(OPND,Operate(a,theta,b));break;
//Operate之後,對C繼續判斷,所以不用getchar()
}
}
s=GetTop2(OPND);
printf("結果為:");
printf("%d\n",s);
return 0;
}