求java实现C语言常用算法的程序(如各种排序算法),以及Java考题

求java实现C语言常用算法的程序(如各种排序算法),以及Java考题,第1张

Java 算法:

public class Sort {

public void swap(int a[], int i, int j) {

int tmp = a[i];

a[i] = a[j];

a[j] = tmp;

}

public int partition(int a[], int low, int high) {

int pivot, p_pos, i;

p_pos = low;

pivot = a[p_pos];

for (i = low + 1; i <= high; i++) {

if (a[i] > pivot) {

p_pos++;

swap(a, p_pos, i);

}

}

swap(a, low, p_pos);

return p_pos;

}

public void quicksort(int a[], int low, int high) {

int pivot;

if (low < high) {

pivot = partition(a, low, high);

quicksort(a, low, pivot - 1);

quicksort(a, pivot + 1, high);

}

}

public static void main(String args[]) {

int vec[] = new int[] { 37, 47, 23, -5, 19, 56 };

int temp;

//选择排序法(Selection Sort)

long begin = SystemcurrentTimeMillis();

for (int k = 0; k < 1000000; k++) {

for (int i = 0; i < veclength; i++) {

for (int j = i; j < veclength; j++) {

if (vec[j] > vec[i]) {

temp = vec[i];

vec[i] = vec[j];

vec[j] = temp;

}

}

}

}

long end = SystemcurrentTimeMillis();

Systemoutprintln("选择法用时为:" + (end - begin));

//打印排序好的结果

for (int i = 0; i < veclength; i++) {

Systemoutprintln(vec[i]);

}

// 冒泡排序法(Bubble Sort)

begin = SystemcurrentTimeMillis();

for (int k = 0; k < 1000000; k++) {

for (int i = 0; i < veclength; i++) {

for (int j = i; j < veclength - 1; j++) {

if (vec[j + 1] > vec[j]) {

temp = vec[j + 1];

vec[j + 1] = vec[j];

vec[j] = temp;

}

}

}

}

end = SystemcurrentTimeMillis();

Systemoutprintln("冒泡法用时为:" + (end - begin));

//打印排序好的结果

for (int i = 0; i < veclength; i++) {

Systemoutprintln(vec[i]);

}

//插入排序法(Insertion Sort)

begin = SystemcurrentTimeMillis();

for (int k = 0; k < 1000000; k++) {

for (int i = 1; i < veclength; i++) {

int j = i;

while (vec[j - 1] < vec[i]) {

vec[j] = vec[j - 1];

j--;

if (j <= 0) {

break;

}

}

vec[j] = vec[i];

}

}

end = SystemcurrentTimeMillis();

Systemoutprintln("插入法用时为:" + (end - begin));

//打印排序好的结果

for (int i = 0; i < veclength; i++) {

Systemoutprintln(vec[i]);

}

//快速排序法(Quick Sort)

Sort s = new Sort();

begin = SystemcurrentTimeMillis();

for (int k = 0; k < 1000000; k++) {

squicksort(vec, 0, 5);

}

end = SystemcurrentTimeMillis();

Systemoutprintln("快速法用时为:" + (end - begin));

//打印排序好的结果

for (int i = 0; i < veclength; i++) {

Systemoutprintln(vec[i]);

}

}

}

以下是运行结果:

选择法用时为:234

56

47

37

23

19

-5

冒泡法用时为:172

56

47

37

23

19

-5

插入法用时为:78

56

47

37

23

19

-5

快速法用时为:297

56

47

37

23

19

-5

资料内容所涉及方面: C/C++/VC++的基础教程、通讯、协议分析、游戏开发、图像处理、管理系统、多媒体、加密与解密、控件ACTIVEX、开发CGI、标准程式库、技术内幕、Windows核心编程、对象模型、人工智能、软件工程、数据结构、WindowsAPI、Visual Basic 、Directx、网络开发、数据库开发、ADO、神经网络、DLL和内存管理、OLE&DDE、 *** 作系统、端口、数值算法、等等技术或相关开发资料。 《C语言专区》 C语言实例教程 172 >

这是我编的一个简易矩阵计算器,C++语言,非常容易理解的,你可以参考求行列式和逆部分

#include <iostream>

#include <iomanip>

#include <conioh>

#include "windowsh"

#include <string>

using namespace std;

void gotoxy(int x,int y) // 列x: 0~79 行y: 0~24

{ HANDLE hConsole=GetStdHandle(STD_OUTPUT_HANDLE);

COORD coordScreen={x,y};

SetConsoleCursorPosition(hConsole,coordScreen);

return;

}

void setcolor(unsigned short ForeColor,unsigned short BackColor)

// 0--黑 1--暗蓝 2--暗绿 3--暗青 4--暗红 5--暗紫 6--蟹黄 7--暗白

// 8--灰 9--亮蓝 10-亮绿 11-亮青 12-亮红 13-亮紫 14-黄 15-亮白

{ HANDLE hCon = GetStdHandle(STD_OUTPUT_HANDLE);

SetConsoleTextAttribute(hCon,(ForeColor % 16)|(BackColor % 16 16));

};

int main()

{

void plu();

void sub();

void amo();

void mul();

void ran();

void ord();

char sel='1';

while(sel != '0')

{ int i;

system("cls"); // 清屏

setcolor(15,0); // 下面显示黑底亮青字

gotoxy(8,1); cout<<"┌───────────────────────────┐";

for(i=2;i<20;i++)

{gotoxy(8,i);cout<<"│";gotoxy(64,i);cout<<"│";}

setcolor(15,6); // 下面显示红底白字

gotoxy(10,3); cout<<" ";

gotoxy(10,4); cout<<" 简 易 矩 阵 计 算 器 ";

gotoxy(10,5); cout<<" ";

setcolor(15,0); // 下面显示黑底亮青字

gotoxy(10,7); cout<<" 1 ---- 矩阵加法 2 ---- 矩阵减法 ";

gotoxy(10,9); cout<<" 3 ---- 矩阵数乘 4 ---- 矩阵乘法 ";

gotoxy(10,11); cout<<" 5 ---- 矩阵行列式 6 ---- 矩阵的逆 ";

gotoxy(10,13); cout<<" 0 ---- 退出 ";

gotoxy(10,15); cout<<" 请选择(0--6):";

gotoxy(8,20); cout<<"└───────────────────────────┘";

do

{ gotoxy(28,15); sel=getche( );}

while ( sel!='1' && sel!='2' && sel!='3' && sel!='4' && sel!='5' && sel!='6'&& sel!='0');

switch(sel)

{

case '1':plu(); break;

case '2':sub(); break;

case '3':amo(); break;

case '4':mul(); break;

case '5':ran(); break;

case '6':ord(); break;

case '0': break;

}

}

system("cls");

gotoxy(25,10);

cout<<"谢 谢 使 用 系 统 !"<<endl;

return 0;

}

void plu()//加法

{ char l;

system("cls"); // 清屏

setcolor(14,0); // 下面用黑底黄字

int a,b,i,j;

gotoxy(0,0);cout<<">>>>>> 矩阵加法 ";

gotoxy(0,2);cout<<"请输入矩阵的行数:";

cin>>a;

cout<<endl;

cout<<"请输入矩阵的列数:";

cin>>b;

cout<<endl;

double m[10][10],n[10][10];

cout<<"请输入第一个矩阵:"<<endl;

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,2i+6); cin>>m[i][j];}

cout<<endl<<endl<<"请输入第二个矩阵:"<<endl;

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,2a+2i+7);cin>>n[i][j];}

cout<<endl<<">>>>>>>"<<endl<<"矩阵加法结果为:";

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,4a+2i+8);cout<<m[i][j]+n[i][j];}

gotoxy(0,6a+9);

cout<<">>>>>>>>按任意键退出:";

l=getche();

}

void sub()//减法

{ char l;

system("cls"); // 清屏

setcolor(14,0); // 下面用黑底黄字

int a,b,i,j;

gotoxy(0,0);cout<<">>>>>矩阵减法";

gotoxy(0,2);cout<<"请输入矩阵的行数:";

cin>>a;

cout<<endl;

cout<<"请输入矩阵的列数:";

cin>>b;

cout<<endl;

double m[10][10],n[10][10];

cout<<"请输入第一个矩阵:"<<endl;

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,2i+6); cin>>m[i][j];}

cout<<endl<<endl<<"请输入第二个矩阵:"<<endl;

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,2a+2i+7);cin>>n[i][j];}

cout<<endl<<">>>>>>>"<<endl<<"矩阵减法结果为:";

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,4a+2i+8);cout<<m[i][j]-n[i][j];}

gotoxy(0,6a+9);

cout<<">>>>>>>>按任意键退出:";

l=getche();

}

void amo()//数乘

{ char h;

system("cls"); // 清屏

setcolor(14,0); // 下面用黑底黄字

int a,b,i,j;

gotoxy(0,0);cout<<">>>>>>矩阵数乘";

gotoxy(0,2);cout<<"请输入矩阵的行数:";

cin>>a;

cout<<endl;

cout<<"请输入矩阵的列数:";

cin>>b;

cout<<endl;

double m[10][10],c;

cout<<"请输入矩阵:"<<endl;

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+20,2i+6);cin>>m[i][j];}

cout<<endl<<"请输入与矩阵相乘的实数:";

cin>>c;

cout<<endl<<endl<<"矩阵数乘结果为:";

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(8j+20,2a+2i+9);cout<<m[i][j]c;}

gotoxy(0,4a+12);

cout<<">>>>>>>按任意键退出:";h=getche();

}

void mul()//乘法

{

char k;

system("cls"); // 清屏

setcolor(14,0); // 下面用黑底黄字

int a,b,c,i,j,q;

gotoxy(0,0);cout<<">>>>>>矩阵乘法";

gotoxy(0,2);cout<<"请输入第一个矩阵的行数:";

cin>>a;

cout<<endl<<"请输入第一个矩阵的列数:";

cin>>b;

cout<<endl<<"则第二个矩阵的行数也为:"<<b;

cout<<endl<<endl<<"请输入第二个矩阵的列数:";

cin>>c;

cout<<endl;

double m[10][10],n[10][10],p[10][10]={0};

cout<<"请输入第一个矩阵:"<<endl;

for(i=0;i<a;i++)

for(j=0;j<b;j++)

{gotoxy(6j+18,2i+10); cin>>m[i][j];}

cout<<endl<<endl<<"请输入第二个矩阵:";

for(i=0;i<b;i++)

for(j=0;j<c;j++)

{gotoxy(6j+18,2a+2i+11);cin>>n[i][j];}

cout<<endl<<">>>>>>>"<<endl<<"矩阵相乘结果为: ";

for(i=0;i<a;i++)

for(j=0;j<c;j++)

for(q=0;q<b;q++) p[i][j]=p[i][j]+m[i][q]n[q][j];

for(i=0;i<a;i++)

for(j=0;j<c;j++)

{gotoxy(10j+18,2a+2b+2i+12);cout<<p[i][j];}

gotoxy(16,2a+2b+2i+15);

cout<<">>>>>>>按任意键退出:";k=getche();

}

//===================================================行列式

float Fun(int n1,float a1[10][10]);

void ran()

{

system("cls"); // 清屏

setcolor(15,0); // 下面用黑底黄字

char k;

int n,i,j;

cout<<">>>>>矩阵行列式"<<endl<<endl<<"请输入矩阵阶数: ";

cin>>n;

cout<<endl<<"请输入矩阵:"<<endl;

float a[10][10];

for(i=0;i<n;i++)

for(j=0;j<n;j++)

{gotoxy(6j+12,2i+4);cin>>a[i][j];}

cout<<endl<<"行列式为: "<<Fun(n,a)<<endl<<endl;

cout<<">>>>>>按任意键退出:";

k=getche();

}

float Fun(int n1,float a1[10][10])//求行列式的递归函数

{

int i_1,j_1,c;//c为数组b的行

float b[10][10];

int p=0,q=0;

float sum=0;

if(n1==1) return a1[0][0];

for(i_1=0;i_1<n1;i_1++)

{

for(c=0;c<n1-1;c++)

{if(c<i_1) p=0;

else p=1;

for(j_1=0;j_1<n1-1;j_1++)

{b[c][j_1]=a1[c+p][j_1+1];}

}

if(i_1%2==0)

q=1;

else q=(-1);

sum=sum+a1[i_1][0]qFun(n1-1,b);

}return sum;

}

//================================================================

void ord()

{

char g;

system("cls"); // 清屏

setcolor(15,0); // 下面用黑底黄字

int i,j,n;

gotoxy(0,0);cout<<">>>>>矩阵的逆";

gotoxy(0,2);cout<<"请输入矩阵的阶数:";

cin>>n;

cout<<endl;

cout<<"请输入矩阵:";

float l[10][10],m[10][10],p;

for(i=0;i<n;i++)

for(j=0;j<n;j++)

{gotoxy(4j+12,2i+4); cin>>l[i][j];}

if(Fun(n,l)==0) cout<<endl<<"该矩阵无逆!!!"<<endl;

else

{p=Fun(n,l);

cout<<endl<<"矩阵的逆为: ";

for(i=0;i<n;i++)

for(j=0;j<n;j++)

{{float f[10][10];

int r,w,e,d;//e为数组f的行数

for(int j_1=0,e=0;j_1<n-1,e<n-1;j_1++,e++)

for(int i_1=0,d=0;i_1<n-1,d<n-1;i_1++,d++)

{if(e<i) r=0;else r=1;

if(d<j) w=0;else w=1;

f[i_1][j_1]=l[i_1+w][j_1+r];};

if((i+j)%2==0) m[i][j]=Fun(n-1,f)/p;

else m[i][j]=-Fun(n-1,f)/p;

};

gotoxy(9j+12,2n+2i+4);cout<<m[i][j];};};

cout<<endl<<endl<<">>>>>>按任意键退出:";g=getche();

}

这里以s为整型数组为例

int search(int x,int s[],int len)

{

for(int i=0;i<len;++i)

{

if (x == s[i])

{

return i;

}

}

return 1;

}

以上就是关于求java实现C语言常用算法的程序(如各种排序算法),以及Java考题全部的内容,包括:求java实现C语言常用算法的程序(如各种排序算法),以及Java考题、怎样才能快速学会C语言编程、用c语言怎么编写输入一个矩阵求其逆矩阵的程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/zz/9294724.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存