C语言/MFC 选择排序

MFC的Edit Control用法
服务器君一共花费了168.393 ms进行了4次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

本文的目的是了解C语言下的选择排序,并分别在C与MFC下实现选择排序。

下面是在MFC下的程序实现:

char tmp[10] = "";
int rand_num[10];
CString str[10];
CString result;
CString sort_result;

void CNM_MFCDlg::OnBnClickedOk()
{
	CEdit* pBoxOne;
	pBoxOne = (CEdit*) GetDlgItem(IDC_EDIT1);

	srand((unsigned)time(NULL));
	for(int x=0; x<10; x++)
	{
		rand_num[x] =  rand()%100;
		str[x] = itoa(rand_num[x],tmp,10);
		result = result + str[x] + _T(" ");
	}

	pBoxOne-> SetWindowText( result );
	//MessageBox(str,_T("程序运行结果"),MB_OK);
	result.ReleaseBuffer();
}

void CNM_MFCDlg::OnBnClickedButton1()
{
	CEdit* pBoxTwo;
	pBoxTwo = (CEdit*) GetDlgItem(IDC_EDIT2);
	selection_sort(rand_num,10);

	for(int x=0; x<10; x++)
	{
		str[x] = itoa(rand_num[x],tmp,10);
		sort_result = sort_result + str[x] + _T(" ");
	}

	sort_result = sort_result + _T("~ \r\n");
	//UpdateData(false);
	pBoxTwo-> SetWindowText( sort_result );
	sort_result.ReleaseBuffer();
}

void CNM_MFCDlg::OnBnClickedCancel()
{
	CDialogEx::OnCancel();
}

void selection_sort(int *a,int n)
{
	int i,j,s;
	for(i=0;i<n-1;i++)
	{
		s=i;
		for(j=i+1;j<n;j++)
		{ 
			if(a[j]<a[i])
			{
				s=j;
			}
		}
		swap(&a[i],&a[s]);
	}
}

/*
	实现两个元素的互换
	原型:void swap(int *p1,int *p2)
	参数:int *p1:元素1的地址 
   		 int *p2:元素2的地址 
*/
void swap(int *p1,int *p2)
{
	int temp;
	temp=*p1;
	*p1=*p2;
	*p2=temp;
}

程序运行结果如下:

关于选择排序算法,其函数这样:

/*
	使用选择排序法进行排序:从小到大;
	void selection_sort(int *a,int n) 
	参数:int *a:数组名
		 int n :排序元素数
*/
void selection_sort(int *a,int n)
{
	int i,j,s;
	for(i=0;i<n-1;i++)
	{
		s=i;
		for(j=i+1;j<n;j++)
		{ 
			if(a[j]<a[i])
			{
				s=j;
			}
		}
		swap(&a[i],&a[s]);
	}
}

关于MFC下Edit Control的换行,可以用下面的方法:

sort_result = sort_result + _T("~ \r\n");

除了使用 \r\n 之外,还要对 CEdit 的属性进行设置:

Auto HScroll 设置为 False, MultiLine 设置为 True,Want Return 设置为 True。

本文地址:http://www.nowamagic.net/librarys/veda/detail/380,欢迎访问原出处。

不打个分吗? 还木有人打分噢!

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/380

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

大家都在看

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《设计模式:可复用面向对象软件的基础》 Erich Gamma (作者), Richard Helm (作者), Ralph Johnson (作者), John Vlissides (作者), 李英军 (译者), 等 (译者)

《设计模式:可复用面向对象软件的基础》是引导读者走出软件设计迷宫的指路明灯,凝聚了软件开发界几十年设计经验的结晶。四位顶尖的面向对象领域专家精心选取了最具价值的设计实践,加以分类整理和命名,并用简洁而易于重用的形式表达出来。本书已经成为面向对象技术人员的圣经和词典,书中定义的23个模式逐渐成为开发界技术交流所必备的基础知识和语汇。

更多计算机宝库...