В знаковом виде, в старшем разряде (самый левый) хранится знак числа: 0 для +, 1 для минус; остальные разряды - само число.
Отрицательное числом может кодироваться в прямом, обратном и дополнительном кодах.
В прямом коде это то же самое положительное, только с другим знаком:
1110 1101
В обратном - все значащие разряды инвертированы:
1001 0010
В дополнительном к обратному коду просто прибавлена единица:
1001 0011
Чаще всего в вычислительной техники пользуются дополнительным кодом, так что подозреваю, что он тебе и нужен.
karpovaveronika196
05.01.2022
#include <iostream> #include <ctime> #include <cstdlib> using namespace std;
int main(){ srand(time(0)); int n,m; cin>>n; cin>>m; int **a=new int *[m]; for(int i=0;i<m;i++) a[i]=new int[n]; cout<<"Matrix A:"; for(int i=0;i<m;i++){ cout<<"\n"; for(int j=0;j<n;j++){ a[i][j]=rand()%17-7; cout<<a[i][j]<<" "; } } int *b = new int[m]; cout<<"\n Array B:"; for(int j=0;j<n;j++){ b[j]=0; for(int i=0;i<m;i++){ b[j]=b[j]+a[i][j]; }cout<<b[j]<<" "; } cin.get(); cin.get(); return 0; }
Olga-Rauisovna
05.01.2022
// PascalABC.NET 3.0, сборка 1073 const m=5; n=4; a:array[1..m] of real=(2,-7.1,3.2,-5.4,6.9); b:array[1..n] of real=(8.1,3.2,-6.4,-3.5); k=3; var i,j:integer; sk:real; s:array[1..m,1..n] of real; begin Writeln('Массив S'); for i:=1 to m do begin for j:=1 to n do begin s[i,j]:=a[i]*b[j]; Write(s[i,j]:7:2) end; Writeln end; sk:=0; for i:=1 to m do sk:=sk+s[i,k]; Writeln('Сумма элементов столбца ',k,' равна ',sk) end.
Результат выполнения программы: Массив S 16.20 6.40 -12.80 -7.00 -57.51 -22.72 45.44 24.85 25.92 10.24 -20.48 -11.20 -43.74 -17.28 34.56 18.90 55.89 22.08 -44.16 -24.15 Сумма элементов столбца 3 равна 2.56
Ответить на вопрос
Поделитесь своими знаниями, ответьте на вопрос:
В8-ми разрядной ячейке памяти в формате со знаком получите внутреннее представление числа а) 109 б) -109 и объясните как это делается
Переведем 109 в двоичную систему: 1*2^6 + 1*2^5 + 0*2^4 + 1*2^3 + 1*2^2 +0*2^1 + 1*2^0:
0110 1101
В знаковом виде, в старшем разряде (самый левый) хранится знак числа: 0 для +, 1 для минус; остальные разряды - само число.
Отрицательное числом может кодироваться в прямом, обратном и дополнительном кодах.
В прямом коде это то же самое положительное, только с другим знаком:
1110 1101
В обратном - все значащие разряды инвертированы:
1001 0010
В дополнительном к обратному коду просто прибавлена единица:
1001 0011
Чаще всего в вычислительной техники пользуются дополнительным кодом, так что подозреваю, что он тебе и нужен.